comp.lang.ada
 help / color / mirror / Atom feed
From: Matthew Heaney <matthewjheaney@earthlink.net>
Subject: Re: GCC 4.0 Ada.Containers Cursor danger.
Date: Tue, 19 Jul 2005 12:44:38 GMT
Date: 2005-07-19T12:44:38+00:00	[thread overview]
Message-ID: <uhder6k3t.fsf@earthlink.net> (raw)
In-Reply-To: gb_Ce.8815$LC6.6336@fe06.lga

Mikhail Terekhov <terekhov@emc.com> writes:

> This is not a restriction. This is clarity. Cursors are not needed for
> iteration. Cursors are a special case, they should be marked as such.

Cursors are tied to the iteration mechanism, because the language
doesn't have support for "real" iterators.


> But membership test is a most basic operation which has exactly the
> same semantics for _any_ container type. This operation should be
> present for all container types and it doesn't depend on order or
> cursors.

But it *is* present for *all* containers, nor does it depend on cursors.
(The operation is named Contains, and returns a Boolean result.)


> You should be able to chose whatever abstraction fits your application
> best and this abstraction should be familiar to anyone who will read
> your source code.

That's why the library comprises a suite of containers: you pick the
container that best fits your needs.


> Sorted sets and hashes probably are very useful in some special cases,
> but they are just a special cases. It is not a very good idea to put
> some special cases as a _basis_ of the standard library. There is
> nothing wrong to put them into standard library, but only as an
> addition to or specialization of basic abstractions.

To what "basic" abstractions are you referring?


> That is wonderful! Almost any example of using cursor doesn't really
> need cursors. Why this burden then?

See section 5 here:

http://www.sgi.com/tech/stl/table_of_contents.html

Several of those algorithms have been converted to Ada for use with the
Charles library (see the operations in Charles.Algorithms.*):

http://charles.tigris.org/source/browse/charles/src/

The next phase of development of the standard library will be to
compliment the containers with a suite of algorithms.  (One problem I
haven't quite figured out is how to best describe a range.)


> Try to think a little bit farther. If there is no order or sorting,
> what is the meaning of First and Last? 

First and Last describe the (half-open) endpoints of a range.  That's
all they mean.  Whether it's important that elements are ordered of
course depends on the algorithm.


> Index sets require indirection which is provided by the core language,
> i.e. access types; they require no cursors.

Note that access types won't work, since the ARG required that
unconstrained types remain mutable when they're container elements.
This is one of the differences between Charles and the standard library.

To be more specific, if you have a record type with a default
discriminant, like this:

   type DT is (A, B, C);
   type RT (D : DT := A) is record ... end record;

then this type has to be allowed as a container element, and you must be
able to mutate the element (that is, change its discriminant) when it's
inside a container.

Access types wouldn't work, since you would have to declare the
container element as "aliased" in order to return an access value, but
that would constrain the object (fix the value of the discriminant).


> Find is not a membership test. 

Of course it's a membership test.  It finds the element in a sequence
that matches a given value.


> Membership test is more generic, i.e it has _the same_ semantics for
> _any_ kind of container, namely "does this container contain this
> element or not?" Membership test is not a replacement for various
> kinds of search and vice versa.

Well, the containers all do have a membership test, named Contains, that
returns type Boolean.  (But containers do have a Find operation too.)


> Find is more diverse and is not always make sense.

OK, then just use Contains if all you want is a membership test.


> For "mappings" i.e. vectors and hashes for example "Find" could return
> a key (index for vectors) of the element or a list/vector/set of keys
> whose elements satisfy some predicate.

Vectors have both a Find (that returns a cursor) and Find_Index (that
returns an index).

If this is a map, and you want a Generic_Find to return a key, then why
not just write it that way?  (You'll have to decide what to return if
the element is not in the map, e.g. return a value that you know can
never be a key).



> If you need just a set of references to some elements, then you are all
> set. Ada provides access types, why cursor?

As explained above, access types wouldn't work.  (A cursor is the
container analog of an access type, but it's at a higher level of
abstraction, since it must hide private representation details.)

Your question is a bit odd, though, since you seem to be advocating that
containers should use access types instead of cursors.  But that doesn't
make any sense, since your earlier complaint was that cursors are too
low-level.


> Cursors could be an implementation detail, they are not needed for
> general API. Start and Stop can have no sense for some
> containers. Algorithm can use internally whatever it needs to deliver
> result.

You're still confused.  Start and Stop describe endpoints of a range,
but that range can be a subset of what's in a container.

Generic algorithms accept a range (described a cursor pair) since it
makes an algorithm container-neutral, and because it allows one to apply
an algorithm to a (logically contiguous) subset of elements.


> Programmers are perfecly able to do their work without Cursors, at
> least most of them (I'm not counting authors of Ada.Containers ;).

And of course you're not counting thousands of C++ programmers either.


> I would say Cursors add "double indirection" :) - for elements and
> container itself.

Yes of course.  The point of a cursor is to abstract-away the container,
and to allow a container element to be manipulated without exposing
container representation.  (Remember my mantra that "Elements are
everything.  Containers are nothing.")


> That would be a disaster :), let's say clear and loudly: "we love
> indirection", and let's use it explicitly via access types.:)

Access types wouldn't work, as explained above.

If you have a container design that uses access types in the interface,
and allows unconstrained types to remain mutable, then please let's see
it.  Perhaps you're using some technique I hadn't thought of.



  reply	other threads:[~2005-07-19 12:44 UTC|newest]

Thread overview: 195+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2005-07-04 11:01 GCC 4.0 Ada.Containers Cursor danger Dmitriy Anisimkov
2005-07-04 18:56 ` Georg Bauhaus
2005-07-04 19:07   ` Georg Bauhaus
2005-07-05  4:27   ` Dmitriy Anisimkov
2005-07-05 15:01     ` Matthew Heaney
2005-07-06  9:10   ` Maxim Reznik
2005-07-06 10:45     ` Georg Bauhaus
2005-07-06 13:57       ` Maxim Reznik
2005-07-06 14:53         ` Georg Bauhaus
2005-07-06 15:09         ` Matthew Heaney
2005-07-06 16:37           ` Dmitriy Anisimkov
2005-07-06 16:43             ` Matthew Heaney
2005-07-06 22:24         ` Randy Brukardt
2005-07-07 10:23         ` Alex R. Mosteo
2005-07-06 12:41     ` Matthew Heaney
2005-07-06 15:37     ` Matthew Heaney
2005-07-06 21:51   ` Randy Brukardt
2005-07-05 14:51 ` Matthew Heaney
2005-07-05 17:11   ` Dmitriy Anisimkov
2005-07-05 18:02     ` Matthew Heaney
2005-07-05 19:08       ` Dmitriy Anisimkov
2005-07-05 19:26         ` Matthew Heaney
2005-07-05 19:44           ` Dmitriy Anisimkov
2005-07-05 20:06             ` Matthew Heaney
2005-07-06  2:10               ` Dmitriy Anisimkov
2005-07-06 22:44                 ` Randy Brukardt
2005-07-07  3:41                   ` Dmitriy Anisimkov
2005-07-07 19:18                     ` Randy Brukardt
2005-07-08  3:01                       ` Dmitriy Anisimkov
2005-07-09  6:17                         ` Simon Wright
2005-07-11  2:24                           ` Dmitriy Anisimkov
2005-07-11  2:24                           ` Dmitriy Anisimkov
2005-07-06  5:52     ` Martin Dowie
2005-07-06  7:02       ` Dmitriy Anisimkov
2005-07-06  8:02         ` Georg Bauhaus
2005-07-06  8:37           ` Dmitriy Anisimkov
2005-07-06  9:06             ` Pascal Obry
2005-07-06 12:14             ` Georg Bauhaus
2005-07-06  7:53       ` Pascal Obry
2005-07-06  8:44         ` Dmitriy Anisimkov
2005-07-06  9:03           ` Pascal Obry
2005-07-06  9:34             ` Dmitriy Anisimkov
2005-07-06  9:42               ` Pascal Obry
2005-07-06  9:45                 ` Dmitriy Anisimkov
2005-07-06 10:40                   ` Georg Bauhaus
2005-07-06 16:22                     ` Dmitriy Anisimkov
2005-07-06 16:42                       ` Matthew Heaney
2005-07-06 16:59                         ` Dmitriy Anisimkov
2005-07-06 17:12                           ` Matthew Heaney
2005-07-06 18:12                       ` Georg Bauhaus
2005-07-07 12:29                         ` Dmitriy Anisimkov
2005-07-07 12:46                           ` Matthew Heaney
2005-07-07 13:01                             ` Dmitriy Anisimkov
2005-07-07 13:20                               ` Matthew Heaney
2005-07-07 13:54                           ` Georg Bauhaus
2005-07-07 17:56                             ` Dmitriy Anisimkov
2005-07-07 22:12                               ` Georg Bauhaus
2005-07-15 18:03                                 ` Dmitriy Anisimkov
2005-07-16  1:45                                   ` Matthew Heaney
2005-07-17  3:55                                     ` Dmitriy Anisimkov
2005-07-17  4:29                                       ` Matthew Heaney
2005-07-07 19:29                           ` Randy Brukardt
2005-07-08  2:41                             ` Dmitriy Anisimkov
2005-07-06 22:56               ` Randy Brukardt
2005-07-06 22:51         ` Randy Brukardt
2005-07-07  0:24           ` Matthew Heaney
2005-07-07  3:20             ` Randy Brukardt
2005-07-06  7:30     ` Dmitry A. Kazakov
2005-07-06  7:50       ` Georg Bauhaus
2005-07-06  8:11         ` Dmitriy Anisimkov
2005-07-06 11:36         ` Dmitry A. Kazakov
2005-07-06 12:14           ` Georg Bauhaus
2005-07-06 23:07           ` Randy Brukardt
2005-07-07  8:01             ` Dmitry A. Kazakov
2005-07-07 10:38               ` Georg Bauhaus
2005-07-07 13:00                 ` Dmitry A. Kazakov
2005-07-07 13:41                   ` Matthew Heaney
2005-07-07 22:12                   ` Georg Bauhaus
2005-07-08  8:48                     ` Dmitry A. Kazakov
2005-07-08 10:41                       ` Georg Bauhaus
2005-07-08 13:03                         ` Dmitry A. Kazakov
2005-07-08 13:31                           ` Matthew Heaney
2005-07-10  2:12                           ` Randy Brukardt
2005-07-10  8:52                             ` Dmitry A. Kazakov
2005-07-11 10:58                               ` Georg Bauhaus
2005-07-11 12:18                                 ` Dmitry A. Kazakov
2005-07-11 13:50                                   ` Georg Bauhaus
2005-07-11 18:38                               ` Randy Brukardt
2005-07-12  8:44                                 ` Dmitry A. Kazakov
2005-07-12 10:33                                   ` Georg Bauhaus
2005-07-12 20:38                                   ` Randy Brukardt
2005-07-08 13:15                       ` Matthew Heaney
2005-07-08 14:02                         ` Dmitry A. Kazakov
2005-07-08 14:52                           ` Matthew Heaney
2005-07-11 14:57                             ` MMM
2005-07-11 18:36                               ` Georg Bauhaus
2005-07-12  2:11                                 ` MMM
2005-07-12 21:47                                   ` Randy Brukardt
2005-07-13  4:31                                     ` MMM
2005-07-13  1:15                                   ` Georg Bauhaus
2005-07-13  2:46                                     ` Matthew Heaney
2005-07-14  4:11                                     ` Mikhail Terekhov
2005-07-14 12:44                                       ` Matthew Heaney
2005-07-19  1:38                                         ` Mikhail Terekhov
2005-07-19  3:21                                           ` Matthew Heaney
2005-07-14 23:03                                       ` Georg Bauhaus
2005-07-15  8:36                                         ` Dmitry A. Kazakov
2005-07-15 10:39                                           ` Georg Bauhaus
2005-07-15 14:10                                             ` Dmitry A. Kazakov
2005-07-15 12:10                                           ` Matthew Heaney
2005-07-19  3:51                                             ` Mikhail Terekhov
2005-07-19 11:35                                               ` Matthew Heaney
2005-07-19  3:11                                         ` Mikhail Terekhov
2005-07-19 12:44                                           ` Matthew Heaney [this message]
2005-07-20  5:20                                             ` Simon Wright
2005-07-21  2:39                                               ` Matthew Heaney
2005-07-21  3:23                                               ` Randy Brukardt
2005-07-19 23:51                                           ` Randy Brukardt
2005-07-20 15:33                                             ` Robert A Duff
2005-07-11 14:56                         ` MMM
2005-07-11 23:24                           ` Matthew Heaney
2005-07-12  3:05                             ` MMM
2005-07-12  5:32                               ` Simon Wright
2005-07-13  2:41                                 ` MMM
2005-07-12 11:16                               ` Georg Bauhaus
2005-07-16 22:28                                 ` Robert A Duff
2005-07-12 13:32                               ` Marc A. Criley
2005-07-12 14:51                                 ` MMM
2005-07-12 15:35                                   ` Matthew Heaney
2005-07-12 18:40                                     ` MMM
2005-07-12 19:12                                       ` Matthew Heaney
2005-07-12 19:42                                         ` MMM
2005-07-12 20:02                                           ` Georg Bauhaus
2005-07-13  3:52                                             ` MMM
2005-07-12 20:13                                           ` Matthew Heaney
2005-07-12 21:38                                     ` Simon Wright
2005-07-12 17:44                                   ` Marc A. Criley
2005-07-12 18:51                                     ` MMM
2005-07-12 19:15                                       ` Matthew Heaney
2005-07-12 19:47                                         ` Georg Bauhaus
2005-07-13  2:20                                           ` Matthew Heaney
2005-07-12 20:00                                         ` MMM
2005-07-12 20:09                                           ` Georg Bauhaus
2005-07-12 20:15                                           ` Matthew Heaney
2005-07-12 21:01                                           ` Randy Brukardt
2005-07-13  4:16                                             ` MMM
2005-07-19 23:58                                               ` Randy Brukardt
2005-07-12 21:59                                         ` Simon Wright
2005-07-12 20:56                                       ` Randy Brukardt
2005-07-14  5:01                                         ` Mikhail Terekhov
2005-07-20  0:10                                           ` Randy Brukardt
2005-07-07 12:36               ` Matthew Heaney
2005-07-07 12:52             ` Dmitriy Anisimkov
2005-07-07 13:52               ` Georg Bauhaus
2005-07-07 17:49               ` Dmitriy Anisimkov
2005-07-07 18:35                 ` Matthew Heaney
2005-07-08 17:52                   ` Craig Carey
2005-07-07 17:50               ` Dmitriy Anisimkov
2005-07-07 19:47               ` Randy Brukardt
2005-07-08  2:28                 ` Dmitriy Anisimkov
2005-07-09 14:20                   ` Matthew Heaney
2005-07-10  1:51                   ` Randy Brukardt
2005-07-10  5:46                     ` Craig Carey
2005-07-10  6:13                       ` Craig Carey
2005-07-11 17:33                       ` OT: Greg and Colin? (was Re: GCC 4.0 Ada.Containers Cursor danger.) Marc A. Criley
2005-07-06 22:34     ` GCC 4.0 Ada.Containers Cursor danger Randy Brukardt
2005-07-07  0:22       ` Matthew Heaney
2005-07-07  3:17         ` Randy Brukardt
2005-07-08  5:34           ` Jeffrey Carter
2005-07-10  1:53             ` Randy Brukardt
2005-07-10 19:32               ` Jeffrey Carter
2005-07-07  3:24         ` Randy Brukardt
2005-07-16 23:24 ` Matthew Heaney
2005-07-17  4:04   ` Dmitriy Anisimkov
2005-07-17  5:01     ` Matthew Heaney
2005-07-17 17:13       ` Dmitriy Anisimkov
2005-07-17 17:36         ` Matthew Heaney
2005-07-17 17:49           ` Dmitriy Anisimkov
2005-07-17 18:12             ` Matthew Heaney
2005-07-17 17:40       ` Dmitriy Anisimkov
2005-07-17 17:50         ` Dmitriy Anisimkov
2005-07-17 18:08         ` Matthew Heaney
2005-07-19  4:36           ` Mikhail Terekhov
2005-07-20  1:59             ` Matthew Heaney
2005-07-20 14:00               ` Pascal Obry
2005-07-20 14:34                 ` Matthew Heaney
2005-07-20 16:51                   ` Pascal Obry
2005-07-20 16:53                   ` Pascal Obry
2005-07-21  3:18                   ` Randy Brukardt
2005-07-20  2:37             ` Robert I. Eachus
2005-08-02 16:59               ` Craig Carey
2005-08-02 20:55                 ` Simon Wright
2005-07-20  7:20             ` Georg Bauhaus
2005-07-17  9:28     ` Georg Bauhaus
2005-07-17 14:26       ` Matthew Heaney
replies disabled

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