From: "Dmitry A. Kazakov" <mailbox@dmitry-kazakov.de>
Subject: Re: Latest suggestion for 202x
Date: Sat, 22 Jun 2019 08:54:34 +0200
Date: 2019-06-22T08:54:34+02:00 [thread overview]
Message-ID: <qekjbb$vu0$1@gioia.aioe.org> (raw)
In-Reply-To: ln8stuk7pu.fsf@kst-u.example.com
On 2019-06-21 22:24, Keith Thompson wrote:
> "Dmitry A. Kazakov" <mailbox@dmitry-kazakov.de> writes:
>> On 2019-06-21 20:12, Keith Thompson wrote:
>>> I *can't* replace A by a function without modifying the code that uses
>>> it.
>>
>> In short if I can't do something then I don't need it, sour grapes...
>>
>>> I suppose containers weaken that argument
>>
>> No, it is no argument regardless.
>>
>> If Ada has problems with array abstraction, and it has, that is
>> irrelevant to the point that this is the *same* abstraction.
>>
>> A language that syntactically distinguish array calls and function calls
>> breaks the abstraction or lacks it completely.
>
> Is breaking that abstraction such a bad thing?
Yes, because abstraction is useful. Arrays have no "physical" meaning.
It is always an artifact of software design, some implementation detail,
not to expose.
> Why *should* array
> indexing and function calls be treated as the same thing?
Because they model the same thing, a mapping, when arrays come in
consideration.
> What about
> record component selection?
Same. It is not mapping of ordered 1st class object to 1st class object
in this case, but surely the syntax sugar of record member selection
must be same for records and functions. And it is, since Ada 2005
started to support dotted notation:
R.X -- Record member *or* call to primitive X of R or ...
> What operations *aren't* function calls?
Ideally there should be none. All built-in syntax forms must be
available for user-defined operations. Ada suffers greatly when it
violates this design principle, e.g. consider "and then", "range", "in",
"'Image" etc.
> But please don't overestimate how much I care about this. In my
> opinion, it's really not that big a deal. I personally like brackets
> better than parentheses for array indexing, but I have no particular
> problem with Ada's choice.
In my view it is a language design problem. I have nothing against
adding further types of brackets: {}, <>, || but they all must be
user-defined.
--
Regards,
Dmitry A. Kazakov
http://www.dmitry-kazakov.de
next prev parent reply other threads:[~2019-06-22 6:54 UTC|newest]
Thread overview: 60+ messages / expand[flat|nested] mbox.gz Atom feed top
2019-06-15 23:59 Latest suggestion for 202x Micah Waddoups
2019-06-16 5:14 ` Jerry
2019-06-16 7:17 ` Dmitry A. Kazakov
2019-06-16 10:22 ` Egil H H
2019-06-16 16:54 ` Maciej Sobczak
2019-06-16 20:09 ` Dmitry A. Kazakov
2019-06-17 6:54 ` Egil H H
2019-06-17 7:42 ` J-P. Rosen
2019-06-17 12:01 ` Mart van de Wege
2019-06-17 13:35 ` Maciej Sobczak
2019-06-17 15:20 ` Dmitry A. Kazakov
2019-06-17 15:32 ` Paul Rubin
2019-06-17 16:43 ` Dmitry A. Kazakov
2019-06-17 21:38 ` Keith Thompson
2019-06-18 15:48 ` Jeffrey R. Carter
2019-06-20 22:21 ` Randy Brukardt
2019-06-21 9:42 ` Dmitry A. Kazakov
2019-06-21 18:12 ` Keith Thompson
2019-06-21 18:43 ` Dmitry A. Kazakov
2019-06-21 20:24 ` Keith Thompson
2019-06-22 6:54 ` Dmitry A. Kazakov [this message]
2019-06-22 8:43 ` Randy Brukardt
2019-06-22 9:00 ` Dmitry A. Kazakov
2019-06-22 17:44 ` Keith Thompson
2019-06-22 18:34 ` Bill Findlay
2019-06-22 18:37 ` Dmitry A. Kazakov
2019-06-23 7:38 ` G.B.
2019-06-23 8:29 ` Dmitry A. Kazakov
2019-06-23 18:34 ` Optikos
2019-06-23 19:20 ` Dennis Lee Bieber
2019-06-22 20:48 ` Optikos
2019-06-22 20:53 ` Optikos
2019-06-23 17:42 ` Dennis Lee Bieber
2019-06-24 5:07 ` J-P. Rosen
2019-06-24 5:40 ` Paul Rubin
2019-06-24 7:16 ` Niklas Holsti
2019-06-26 18:00 ` Stephen Leake
2019-06-24 13:07 ` J-P. Rosen
2019-06-24 11:12 ` Stefan.Lucks
2019-06-24 12:06 ` Niklas Holsti
2019-06-24 20:22 ` Randy Brukardt
2019-06-24 20:32 ` Keith Thompson
2019-06-24 20:47 ` Jeffrey R. Carter
2019-06-24 13:10 ` J-P. Rosen
2019-06-22 8:36 ` Randy Brukardt
2019-06-22 17:39 ` Keith Thompson
2019-06-16 19:34 ` Optikos
2019-06-16 20:10 ` John Perry
2019-06-16 20:57 ` Optikos
2019-06-16 21:36 ` Dmitry A. Kazakov
2019-06-17 16:48 ` G. B.
2019-06-17 17:12 ` Paul Rubin
2019-06-16 21:41 ` Lucretia
2019-06-19 2:36 ` Micah Waddoups
2019-06-19 11:14 ` Lucretia
2019-06-19 11:45 ` briot.emmanuel
2019-06-19 14:34 ` Optikos
2019-06-19 19:29 ` Lucretia
2019-06-19 16:12 ` G. B.
2019-06-23 20:17 ` Per Sandberg
replies disabled
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox