From: Robert A Duff <bobduff@shell01.TheWorld.com>
Subject: Re: Elaboration order handling (Was: Bug in 'gnatmake')
Date: Wed, 19 Jun 2013 20:31:42 -0400
Date: 2013-06-19T20:31:42-04:00 [thread overview]
Message-ID: <wcc38sd7hch.fsf@shell01.TheWorld.com> (raw)
In-Reply-To: kptb6c$gh$1@loke.gir.dk
"Randy Brukardt" <randy@rrsoftware.com> writes:
> "Robert A Duff" <bobduff@shell01.TheWorld.com> wrote in message
> news:wccip1acmt5.fsf@shell01.TheWorld.com...
> ...
>> I don't see what the big deal is. Any legal Ada identifier can be
>> represented as a Wide_Wide_String, and every Ada 2012 implementation
>> supports the "<" operator on those. So one trivial solution is to
>> simply sort based on that "<", in cases where the current rules about
>> 'with' clauses and pragmas leave the order undefined.
>
> That doesn't work because Ada identifiers are case-insensitive, while "<" is
> case-sensitive. You could get orders that depend on the case of the
> identifiers,
Groan. More proof of the theorem, "Nothing is simple."
>...and in fact you could get children coming before parents.
No, no. All the existing elab-order requirements would still apply.
I'm suggesting only that we'd be better off if the cases where the
current rules allow an implementation-defined order were language
defined.
Certainly a child package spec can't be elaborated before its parent spec!
> A direct conversion to some specific case doesn't work portably in Unicode
> (because it depends on what version Unicode you are using, while the
> case-insensitive compare is guarenteed to work the same in all versions of
> Unicode).
Wait, are you saying that it's impossible to implement a
case-insensitive sort in unicode? Such a sort is all that's needed
here.
Anyway, there's some "perfect/enemy/good-enough" thing going on here.
Even solving the problem for programs that use only plain-old 7-bit ASCII
would have saved zillions of dollars.
> The net effect is that ordering is not very reliable in case-insensitive
> Unicode identifiers, like Ada's. Cool, huh?
Bleah.
- Bob
next prev parent reply other threads:[~2013-06-20 0:31 UTC|newest]
Thread overview: 57+ messages / expand[flat|nested] mbox.gz Atom feed top
2013-06-17 10:57 Range check for type 'Integer' Peter Brooks
2013-06-17 11:23 ` Simon Clubley
2013-06-17 11:54 ` Simon Wright
2013-06-17 12:55 ` Peter Brooks
2013-06-17 13:28 ` Shark8
2013-06-17 13:45 ` Peter Brooks
2013-06-17 21:16 ` Shark8
2013-06-18 10:48 ` Stephen Leake
2013-06-17 12:46 ` Dmitry A. Kazakov
2013-06-17 13:23 ` Bug in 'gnatmake' (Was: Range check for type 'Integer') Jacob Sparre Andersen
2013-06-17 13:32 ` Bug in 'gnatmake' Jacob Sparre Andersen
2013-06-17 16:50 ` Bug in 'gnatmake' (Was: Range check for type 'Integer') Robert A Duff
2013-06-17 19:15 ` Peter Brooks
2013-06-17 21:09 ` Shark8
2013-06-17 21:22 ` Jeffrey Carter
2013-06-18 1:21 ` Peter Brooks
2013-06-18 6:33 ` Jeffrey Carter
2013-06-18 7:29 ` Georg Bauhaus
2013-06-17 18:49 ` Bug in 'gnatmake' Simon Wright
2013-06-18 9:09 ` Elaboration order handling (Was: Bug in 'gnatmake') Jacob Sparre Andersen
2013-06-18 17:09 ` Robert A Duff
2013-06-18 22:52 ` Adam Beneschan
2013-06-19 1:21 ` Jeffrey Carter
2013-06-19 12:38 ` Robert A Duff
2013-06-19 20:43 ` Georg Bauhaus
2013-06-20 0:37 ` Robert A Duff
2013-06-20 19:56 ` Georg Bauhaus
2013-06-19 12:22 ` Robert A Duff
2013-06-19 15:46 ` Adam Beneschan
2013-06-19 16:41 ` Robert A Duff
2013-06-19 20:47 ` Georg Bauhaus
2013-06-19 21:36 ` Adam Beneschan
2013-06-20 0:57 ` Robert A Duff
2013-06-20 1:09 ` Jeffrey Carter
2013-06-20 2:29 ` Adam Beneschan
2013-06-20 6:08 ` Jeffrey Carter
2013-06-20 15:11 ` Robert A Duff
2013-06-21 5:26 ` Jeffrey Carter
2013-06-21 15:48 ` Adam Beneschan
2013-06-21 18:35 ` Jeffrey Carter
2013-06-21 19:10 ` Robert A Duff
2013-06-21 21:27 ` Jeffrey Carter
2013-06-21 20:43 ` Adam Beneschan
2013-06-21 21:44 ` Jeffrey Carter
2013-06-21 23:47 ` Robert A Duff
2013-06-23 14:43 ` AdaMagica
2013-06-21 18:58 ` null declarative parts (was: Re: Elaboration order handling) Robert A Duff
2013-06-21 20:42 ` null declarative parts Georg Bauhaus
2013-06-20 2:11 ` Elaboration order handling (Was: Bug in 'gnatmake') Adam Beneschan
2013-06-20 14:44 ` Robert A Duff
2013-06-20 11:24 ` G.B.
2013-06-20 15:23 ` Robert A Duff
2013-06-19 21:00 ` Georg Bauhaus
2013-06-19 22:26 ` Randy Brukardt
2013-06-20 0:31 ` Robert A Duff [this message]
2013-06-20 21:36 ` Randy Brukardt
2013-06-19 13:07 ` Bill Findlay
replies disabled
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox