comp.lang.ada
 help / color / mirror / Atom feed
From: Georg Bauhaus <rm.dash-bauhaus@futureapps.de>
Subject: Re: Hiding the value of Constants
Date: Wed, 08 Jul 2009 12:25:23 +0200
Date: 2009-07-08T12:25:23+02:00	[thread overview]
Message-ID: <4a547413$0$31878$9b4e6d93@newsspool3.arcor-online.net> (raw)
In-Reply-To: <1q139ij9zy8ap.1vnc5u4ncqdxb.dlg@40tude.net>

Dmitry A. Kazakov schrieb:
> On Tue, 7 Jul 2009 13:28:01 -0700 (PDT), Adam Beneschan wrote:
> 
>> On Jul 7, 12:53 pm, "Dmitry A. Kazakov" <mail...@dmitry-kazakov.de>
>> wrote:
>>> On Tue, 7 Jul 2009 12:05:40 -0700 (PDT), Adam Beneschan wrote:
>>>> On Jul 7, 11:48 am, "Dmitry A. Kazakov" <mail...@dmitry-kazakov.de>
>>>> wrote:
>>>>> On Tue, 7 Jul 2009 08:51:35 -0700 (PDT), Adam Beneschan wrote:
>>>>>> I believe the reason enumeration literals are actually functions is so
>>>>>> that you can use the same enumeration literal in more than one
>>>>>> enumeration type and not have to worry about name conflicts.
>>>>> It is a strange explanation to me. There is no obvious reason why rules
>>>>> about overloading named objects should be different for functions. The
>>>>> effect is same, so the syntactic form should be same.
>>>>>> The
>>>>>> overloading rules will allow the compiler to figure out which one is
>>>>>> meant.  There are additional bonuses, such as being able to use an
>>>>>> enumeration literal as the actual for a generic instantiation that
>>>>>> expects a function.  How useful that is in practice, I don't know.
>>>>> It is indeed useful, because sometimes it is impossible to declare a ting
>>>>> as an initialized constant. In such cases making it a function gives the
>>>>> desired effect.
>>>>> [...]
>>>>>> If you mean that you'd like
>>>>>> constants to be treated like static functions, so that you can
>>>>>> overload them:
>>>>>>     Max : constant Integer := 15;
>>>>>>     Max : constant Float := 15.0;
>>>>>> that's an intriguing idea.
>>>>> I think the idea is rather straightforward. But also
>>>>>    X : Integer;
>>>>>    X : Float;
>>>> I'm just guessing here, but I think a big potential problem would be

[...]

> I believe, nobody is satisfied how the rules handle subprograms
> and primitive operations. It is too easy to design a package specification
> which would make it unusable because of ambiguities introduced by
> "use"-ing. Yes prefix notation makes life easier, but it does not
> exterminate need in "use". Something quite radical has to be done about it
> anyway. One spends virtually hours trying to find a reason why the compiler
> rejects an interpretation the programmer sees as "obvious".

The programmer seeing something as "obvious" is a hint to
what the problem with overloading actually is, and what the
(radical) solution looks like.  (Really radical, in a gardening
sense, sort of. :-)   Here, again, is the Max example:

   Max : constant Integer := 15;
   Max : constant Float := 15.0;

What seems obvious to me is that the programmer intends to
express the Max of two somethings that share some common
property: they both have a Max.  But he/she wishes to do so
*without* explicitly programming the underlying common
structure!  Perhaps it seemed obvious when writing the code,
or being lazy and not explicitly programming the common
property seemed justifiable at the time of writing.
IMHO this is an example of the presumption of "being obvious"
making things unecessarily complicated: the compiler would
have to resolve the overload that was introduced by the
programmer who *knew* how to resolve both the commonality
and the difference. (There are means in Ada to express
the same algorithm for two data structures, but anyway ...)

The radical solution is to finally get rid of overloading!
Just use one name for one thing in one region.  See SPARK
for an example.

In Ada, not using generics, but using overridden Max,

   Bounded_Structure: Finite_Order'class := ...;
begin
   if Item < Bounded_Structure.Max then
      ...



  reply	other threads:[~2009-07-08 10:25 UTC|newest]

Thread overview: 23+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2009-07-07  8:48 Hiding the value of Constants Rick
2009-07-07  8:54 ` xavier grave
2009-07-07  8:58   ` AdaMagica
2009-07-07  9:41 ` Georg Bauhaus
2009-07-07 10:41   ` Hibou57 (Yannick Duchêne)
2009-07-07 15:51     ` Adam Beneschan
2009-07-07 16:26       ` Hibou57 (Yannick Duchêne)
2009-07-07 18:48       ` Dmitry A. Kazakov
2009-07-07 19:05         ` Adam Beneschan
2009-07-07 19:53           ` Dmitry A. Kazakov
2009-07-07 20:28             ` Adam Beneschan
2009-07-07 20:57               ` Dmitry A. Kazakov
2009-07-08 10:25                 ` Georg Bauhaus [this message]
2009-07-08 12:20                   ` Dmitry A. Kazakov
2009-07-09 23:04 ` anon
2009-07-10  6:37   ` AdaMagica
2009-07-11 19:06     ` anon
2009-07-11 19:26       ` Georg Bauhaus
2009-07-11 21:53         ` anon
2009-07-11 22:03           ` Albrecht Käfer
2009-07-11 22:15           ` Ed Falis
2009-07-15  9:30             ` anon
2009-07-11 23:31           ` Egil
replies disabled

This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox