From mboxrd@z Thu Jan 1 00:00:00 1970 X-Spam-Checker-Version: SpamAssassin 3.4.4 (2020-01-24) on polar.synack.me X-Spam-Level: X-Spam-Status: No, score=-1.9 required=5.0 tests=BAYES_00 autolearn=unavailable autolearn_force=no version=3.4.4 Path: eternal-september.org!reader01.eternal-september.org!reader02.eternal-september.org!feeder.eternal-september.org!aioe.org!.POSTED!not-for-mail From: "Dmitry A. Kazakov" Newsgroups: comp.lang.ada Subject: Re: Array conversion and bounds Date: Sun, 15 Apr 2018 15:24:57 +0200 Organization: Aioe.org NNTP Server Message-ID: References: NNTP-Posting-Host: kQkuQcRDy1QFvWpyB1foYw.user.gioia.aioe.org Mime-Version: 1.0 Content-Type: text/plain; charset=utf-8; format=flowed Content-Transfer-Encoding: 8bit X-Complaints-To: abuse@aioe.org User-Agent: Mozilla/5.0 (Windows NT 10.0; WOW64; rv:52.0) Gecko/20100101 Thunderbird/52.7.0 Content-Language: en-US X-Notice: Filtered by postfilter v. 0.8.3 Xref: reader02.eternal-september.org comp.lang.ada:51513 Date: 2018-04-15T15:24:57+02:00 List-Id: On 2018-04-15 15:11, Niklas Holsti wrote: > On 18-04-15 15:34 , Dmitry A. Kazakov wrote: >> On 2018-04-15 12:37, Niklas Holsti wrote: >>> On 18-04-15 12:36 , Dmitry A. Kazakov wrote: >>>> Do array bounds slide during conversion? Consider this: >>>> >>>>    type A is array (Integer range <>) of Whatever; >>>>    type B is array (Unsigned_32 range <>) of Whatever; >>>> >>>>    X : A (-10..-1); >>>>    Y : B (1..10); >>>> begin >>>>    Y := B (X); -- Is this OK? >>>> >>>> If bounds slide it must be OK, if bounds do not slide, it must raise >>>> Constraint_Error. >>>> >>>> Any language lawyers? >>> >>> I believe the bounds should _not_ slide, because the "target subtype" >>> of the conversion is type B, which is an _unconstrained_ array subtype. >> >> Better to say, they should, but they do not. > > Ok, if I read the RM correctly (and you seem to agree with me) they "do > not" slide when the target subtype is unconstrained. It is an unsafe choice, obviously. >> Clearly conversions like this should not require resorting to >> Unchecked_Conversion. > > Is there some reason why you cannot use the constrained-target-subtype > method to force sliding? Considering this example: type A is array (Integer range <>) of Whatever; type B is array (Unsigned_32 range <>) of Whatever; X : A (-1000..-1); Y : B (1..200); begin Y (10..19) := B (X (-19..-10)); Do you propose this? declare subtype BB is B (10..19); begin Y (10..19) := BB (X (-19..-10)); end; -- Regards, Dmitry A. Kazakov http://www.dmitry-kazakov.de