From: "Dmitry A. Kazakov" <mailbox@dmitry-kazakov.de>
Subject: Re: operation can be dispatching in only one type
Date: Tue, 1 Dec 2015 18:58:38 +0100
Date: 2015-12-01T18:58:38+01:00 [thread overview]
Message-ID: <ycdffnxx7tqh.ynrajxx67c51$.dlg@40tude.net> (raw)
In-Reply-To: n3kgbn$q6o$1@dont-email.me
On Tue, 1 Dec 2015 17:05:28 +0100, in comp.lang.ada you wrote:
> On 01.12.15 14:56, Dmitry A. Kazakov wrote:
>> On Tue, 1 Dec 2015 12:19:02 +0100, G.B. wrote:
>>
>>> On 01.12.15 09:46, Dmitry A. Kazakov wrote:
>>
>>>> There is no reason why indexing or record member access
>>>> should be less efficient when a user-defined implementation allowed, but
>>>> not actually used.
>>>
>>> Sounds a bit like user defined aspects of compilation?
>>
>> It is not an aspect. Aspect is a view, characteristic, feature:
>>
>> http://www.thefreedictionary.com/aspect
>>
>> It means that aspect may not change the semantics.
>>
>> User-defined operation is exactly the opposite. It does not change the
>> view. The object is still viewed as an array or a record. It is the
>> semantics that gets changed.
>
> I take it that by "semantics" you mean the simplest meaning
> of this word, viz. the operations that happen to become generated
> for a ".X" function, say, as a consequence of compilation?
>
> If, however, a user may define what "rec.x" will do, then
> this changes an aspect (sic) of compilation: what was previously
> defined by the LRM (or would appear to be defined by the
> language) does now seem to flow from the job of the programmer,
> and becomes a property of the program, as it redefines certain
> occurrences of ".".
Who cares? Less defined by the RM then better. Any predefined semantics is
a necessary evil. If not necessary, then just evil.
> The compiler now needs to ensure something different when
> translating "rec.x".
The compiler needs to ensure what the programmer means (assuming correct
language use)
>>> What
>>> guarantees would the compiler be able to generate that user
>>> defined mechanics will work at the same level of assurance
>>> as that of "regular" records?
>>
>> Generated guaranties? You lost me here.
>
> The current Ada language makes the compiler emit code for "Rec.X"
> that is going to have a somewhat predictable effect.
It does not make sense. For *any* legal construct the compiler should emit
code with a predictable effect. Otherwise the language is ill-defined.
The correct sentence is probably related to the program readability. That
is up to the programmer and how he expresses the problem space in the
language terms. I don't see how Employee.Salary is less readable,
predictable, etc than Get_Salary(Employee).
> If users are allowed to change the semantics of "rec.x", then
> what level of assurance do we get?
Same level as when the users are allowed to change the semantics of Foo(x),
x+y etc.
> We'd take away a basic building
> block from the set of unequivocally predictable building blocks.
Member extraction/setting operations is not a basic building block.
Oh, I forgot, that you are in the anti-typed camp. So let me explain. There
is *no* free operations. There are only types. The member operation .X is
one of the built-in operations of the built-in record type. You don't loose
it in no way if you allow *other* types have operations named this way or
implementing same abstract interface. If you don't believe me, look at
fully qualified names, they have "." inside. What a horror!
--
Regards,
Dmitry A. Kazakov
http://www.dmitry-kazakov.de
next prev parent reply other threads:[~2015-12-01 17:58 UTC|newest]
Thread overview: 132+ messages / expand[flat|nested] mbox.gz Atom feed top
2015-11-23 10:23 operation can be dispatching in only one type Serge Robyns
2015-11-23 11:29 ` Dmitry A. Kazakov
2015-11-23 13:05 ` Serge Robyns
2015-11-23 13:48 ` Dmitry A. Kazakov
2015-11-23 14:16 ` Serge Robyns
2015-11-23 14:59 ` G.B.
2015-11-23 15:52 ` Dmitry A. Kazakov
2015-11-23 17:40 ` Jeffrey R. Carter
2015-11-24 9:08 ` Serge Robyns
2015-11-24 16:44 ` AdaMagica
2015-11-24 17:09 ` Jeffrey R. Carter
2015-11-24 18:37 ` Serge Robyns
2015-11-24 20:18 ` Jeffrey R. Carter
2015-11-24 20:40 ` Serge Robyns
2015-11-24 20:25 ` Niklas Holsti
2015-11-24 21:48 ` Jeffrey R. Carter
2015-11-25 8:24 ` Dmitry A. Kazakov
2015-11-25 11:22 ` Serge Robyns
2015-11-25 17:38 ` Dmitry A. Kazakov
2015-11-26 11:30 ` Serge Robyns
2015-11-26 13:14 ` Dmitry A. Kazakov
2015-11-26 14:27 ` Serge Robyns
2015-11-26 15:16 ` J-P. Rosen
2015-11-26 18:27 ` Serge Robyns
2015-11-26 21:20 ` J-P. Rosen
2015-11-27 8:37 ` Dmitry A. Kazakov
2015-11-27 12:58 ` J-P. Rosen
2015-11-27 13:39 ` Dmitry A. Kazakov
2015-11-30 22:22 ` Randy Brukardt
2015-12-01 8:46 ` Dmitry A. Kazakov
2015-12-01 11:19 ` G.B.
2015-12-01 13:56 ` Dmitry A. Kazakov
2015-12-01 16:05 ` G.B.
2015-12-01 17:58 ` Dmitry A. Kazakov [this message]
2015-12-02 13:06 ` G.B.
2015-12-02 13:31 ` Dmitry A. Kazakov
2015-12-02 19:33 ` Randy Brukardt
2015-12-02 19:27 ` Randy Brukardt
2015-11-29 17:59 ` Jacob Sparre Andersen
2015-11-30 22:29 ` Randy Brukardt
2015-11-25 12:27 ` G.B.
2015-11-25 17:25 ` Dmitry A. Kazakov
-- strict thread matches above, loose matches on Subject: below --
2009-11-13 20:12 Operation " xorque
2009-11-13 20:34 ` Dmitry A. Kazakov
2009-11-13 20:43 ` xorque
2009-11-13 21:14 ` Dmitry A. Kazakov
2009-11-13 20:44 ` xorque
2009-11-16 17:43 ` Adam Beneschan
2009-11-16 20:28 ` Dmitry A. Kazakov
2009-11-16 20:32 ` Dmitry A. Kazakov
2009-11-16 21:35 ` Adam Beneschan
2009-11-16 22:28 ` Dmitry A. Kazakov
2009-11-17 22:10 ` Adam Beneschan
2009-11-18 9:46 ` Dmitry A. Kazakov
2009-11-18 16:39 ` Adam Beneschan
2009-11-18 19:21 ` Dmitry A. Kazakov
2009-11-19 0:27 ` Randy Brukardt
2009-11-19 2:11 ` Robert A Duff
2009-11-19 15:57 ` Adam Beneschan
2009-11-19 19:39 ` Robert A Duff
2009-11-19 23:43 ` Randy Brukardt
2009-11-19 8:50 ` Dmitry A. Kazakov
2009-11-19 23:54 ` Randy Brukardt
2009-11-20 8:34 ` Dmitry A. Kazakov
2009-11-20 10:58 ` Jean-Pierre Rosen
2009-11-21 6:02 ` Randy Brukardt
2009-11-21 13:07 ` Dmitry A. Kazakov
2009-11-22 5:45 ` xorque
2009-11-22 11:25 ` Georg Bauhaus
2009-11-22 11:30 ` xorque
2009-11-22 16:25 ` Dmitry A. Kazakov
2009-11-22 16:27 ` xorque
2009-11-22 16:42 ` Dmitry A. Kazakov
2009-11-22 16:52 ` xorque
2009-11-22 17:41 ` Dmitry A. Kazakov
2009-11-22 18:03 ` xorque
2009-11-22 18:08 ` xorque
2009-11-22 18:28 ` Dmitry A. Kazakov
2009-11-22 18:41 ` xorque
2009-11-22 21:47 ` Robert A Duff
2009-11-23 3:42 ` stefan-lucks
2009-11-30 20:36 ` Robert A Duff
2009-11-30 23:54 ` (see below)
2009-12-01 12:13 ` Georg Bauhaus
2009-12-01 12:23 ` Georg Bauhaus
2009-12-01 12:44 ` Georg Bauhaus
2009-12-01 13:48 ` Dmitry A. Kazakov
2009-12-01 15:02 ` Georg Bauhaus
2009-12-01 16:18 ` Dmitry A. Kazakov
2009-12-01 17:52 ` Georg Bauhaus
2009-12-01 18:47 ` Dmitry A. Kazakov
2009-12-01 21:53 ` John B. Matthews
2009-12-02 0:32 ` Georg Bauhaus
2009-12-02 11:18 ` John B. Matthews
2009-12-02 14:29 ` Jean-Pierre Rosen
2009-12-02 15:35 ` Georg Bauhaus
2009-12-02 1:13 ` Georg Bauhaus
2009-12-02 9:07 ` Dmitry A. Kazakov
2009-12-02 12:35 ` John B. Matthews
2009-12-02 13:35 ` Dmitry A. Kazakov
2009-12-03 5:23 ` Randy Brukardt
2009-12-03 20:21 ` John B. Matthews
2009-12-03 5:29 ` Randy Brukardt
2009-12-03 11:24 ` Georg Bauhaus
2009-12-03 23:08 ` Randy Brukardt
2009-12-04 8:52 ` Dmitry A. Kazakov
2009-12-05 2:45 ` Randy Brukardt
2009-12-05 10:32 ` Dmitry A. Kazakov
2009-12-08 0:19 ` Randy Brukardt
2009-12-08 4:30 ` stefan-lucks
2009-12-08 9:12 ` Dmitry A. Kazakov
2009-12-10 4:09 ` Randy Brukardt
2009-12-11 0:10 ` Robert A Duff
2009-12-08 9:22 ` Dmitry A. Kazakov
2009-12-08 10:06 ` Georg Bauhaus
2009-12-08 10:23 ` Dmitry A. Kazakov
2009-12-08 10:33 ` Georg Bauhaus
2009-12-08 10:49 ` Dmitry A. Kazakov
2009-12-01 23:51 ` Randy Brukardt
2009-11-23 8:52 ` Dmitry A. Kazakov
2009-11-30 20:43 ` Robert A Duff
2009-12-01 9:00 ` Dmitry A. Kazakov
2009-12-01 5:45 ` stefan-lucks
2009-12-01 11:12 ` Dmitry A. Kazakov
2009-12-01 8:01 ` stefan-lucks
2009-12-01 13:37 ` Dmitry A. Kazakov
2009-12-15 23:54 ` Robert A Duff
2009-11-23 7:48 ` Georg Bauhaus
2009-11-23 7:58 ` Georg Bauhaus
2009-11-19 16:04 ` Adam Beneschan
2009-11-19 2:23 ` tmoran
2009-11-19 8:32 ` Dmitry A. Kazakov
replies disabled
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox