From: "Dmitry A. Kazakov" <mailbox@dmitry-kazakov.de>
Subject: Re: Proposal: Auto-allocation of Indefinite Objects
Date: Fri, 21 Aug 2020 08:46:07 +0200 [thread overview]
Message-ID: <rhnqjf$bga$2@gioia.aioe.org> (raw)
In-Reply-To: rhn11v$sem$1@franka.jacob-sparre.dk
On 21/08/2020 01:30, Randy Brukardt wrote:
> "Dmitry A. Kazakov" <mailbox@dmitry-kazakov.de> wrote in message
> news:rhmd3m$1eql$2@gioia.aioe.org...
>> On 20/08/2020 02:10, Randy Brukardt wrote:
>>> "Dmitry A. Kazakov" <mailbox@dmitry-kazakov.de> wrote in message
>>> news:rgr267$1o1n$1@gioia.aioe.org...
>>>> No, from the abstraction point of view they do not. They indeed abstract
>>>> the memory allocation aspect, but they do that at the cost of
>>>> *everything*
>>>> else. Unbounded_String is no string anymore. Container is neither array
>>>> nor record type. Unbounded_String must be converted forth and back. For
>>>> containers I must use ugly hacks like iterators to make them resemble
>>>> arrays and records introducing whole levels of complexity to fight
>>>> through
>>>> every time the compiler or I miss something.
>>>>
>>>> In most cases I prefer to keep a clear array or record interface at the
>>>> expense of manual memory management.
>>>>
>>>>> There's no free lunch.
>>>>
>>>> I think with a better type system there could be a whole banquet. (:-))
>>>
>>> Maybe. but IMHO a better type system would get rid of arrays and strings
>>> altogether and only have containers/records of various sorts. The
>>> complexity
>>> of having both solving the same problems (not very well in the case of
>>> arrays/strings) doesn't buy much. I suspect that a user-defined "." as
>>> you've proposed elsewhere would eliminate most of the rest of the
>>> problems
>>> (and unify everything even further).
>>
>> But records and arrays are needed as building blocks of containers. How
>> would you get rid of them?
>
> There's no reason that a compiler couldn't "build-in" a simple bounded
> vector container as the basic building block.
That simply replaces the word "array" with four words "simple bounded
vector container." The construct is still there and it is still
built-in. The syntax and usability are drastically worse, though.
> One could do something similar for records, although I would probably leave
> them as in Ada and just allow user-definition of "." (via a getter/setter
> pair).
Ditto.
--
Regards,
Dmitry A. Kazakov
http://www.dmitry-kazakov.de
next prev parent reply other threads:[~2020-08-21 6:46 UTC|newest]
Thread overview: 47+ messages / expand[flat|nested] mbox.gz Atom feed top
2020-04-03 22:48 Proposal: Auto-allocation of Indefinite Objects Stephen Davies
2020-04-03 23:45 ` Stephen Leake
2020-04-04 10:54 ` Jeffrey R. Carter
2020-04-04 20:55 ` Stephen Davies
2020-04-04 8:31 ` Dmitry A. Kazakov
2020-07-27 7:47 ` Yannick Moy
2020-07-27 9:21 ` J-P. Rosen
2020-07-27 9:49 ` Dmitry A. Kazakov
2020-07-27 17:48 ` Brian Drummond
2020-07-27 20:02 ` Dmitry A. Kazakov
2020-07-28 14:28 ` Brian Drummond
2020-07-28 14:59 ` Dmitry A. Kazakov
2020-07-29 15:33 ` Brian Drummond
2020-07-29 16:20 ` Dmitry A. Kazakov
2020-07-30 13:37 ` Stephen Davies
2020-07-30 14:23 ` Dmitry A. Kazakov
2020-07-30 17:04 ` Brian Drummond
2020-07-30 18:28 ` Dmitry A. Kazakov
2020-08-10 0:39 ` Randy Brukardt
2020-08-10 8:57 ` Dmitry A. Kazakov
2020-08-20 0:10 ` Randy Brukardt
2020-08-20 17:49 ` Dmitry A. Kazakov
2020-08-20 20:19 ` Dennis Lee Bieber
2020-08-20 23:33 ` Randy Brukardt
2020-08-21 6:45 ` Dmitry A. Kazakov
2020-08-23 4:52 ` Randy Brukardt
2020-08-23 12:28 ` Dmitry A. Kazakov
2020-08-20 23:30 ` Randy Brukardt
2020-08-21 6:46 ` Dmitry A. Kazakov [this message]
2020-08-23 4:48 ` Randy Brukardt
2020-08-23 12:29 ` Dmitry A. Kazakov
2020-08-10 0:31 ` Randy Brukardt
2020-08-10 8:58 ` Dmitry A. Kazakov
2020-08-20 0:13 ` Randy Brukardt
2020-08-20 17:49 ` Dmitry A. Kazakov
2020-08-20 23:25 ` Randy Brukardt
2020-08-21 7:08 ` Dmitry A. Kazakov
2020-08-23 5:03 ` Randy Brukardt
2020-08-23 12:28 ` Dmitry A. Kazakov
2020-07-27 20:31 ` Jeffrey R. Carter
2020-07-31 9:25 ` Stephen Davies
2020-07-31 10:20 ` Dmitry A. Kazakov
2020-08-01 11:22 ` Stephen Davies
2020-08-01 12:58 ` Dmitry A. Kazakov
2020-08-01 20:35 ` Stephen Davies
2020-08-01 20:56 ` Dmitry A. Kazakov
2020-09-03 4:30 ` linda white
replies disabled
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox