comp.lang.ada
 help / color / mirror / Atom feed
From: "Yannick Duchêne (Hibou57)" <yannick_duchene@yahoo.fr>
Subject: Re: Why no Ada.Wide_Directories?
Date: Fri, 21 Oct 2011 22:36:03 +0200
Date: 2011-10-21T22:36:03+02:00	[thread overview]
Message-ID: <op.v3px6dk6ule2fv@index.ici> (raw)
In-Reply-To: 1xuiads70kb6s$.odhmr2fg9b0z.dlg@40tude.net

Le Fri, 21 Oct 2011 22:02:55 +0200, Dmitry A. Kazakov  
<mailbox@dmitry-kazakov.de> a écrit:
> You wrote about the implementation being sufficient, which is evidently
> wrong.
>
> The interface = an array of code points indexed by some cardinal number  
> is
> sufficient. The implementation = Wide_Wide_String is not.
That's what I wanted to mean: array interface implemented with its most  
naive implementation. The interface is good and is Ada side, the  
implementation may vary, and is compiler side.

> Ada does not allow you multiple implementations for this interface  
> forming
> one class of types. Ada does not allow you constrained subtypes of the
> interface, e.g. narrower sets of code points (String), narrower ranges of
> the index (small embedded targets). Ada does not allow you alternative
> implementations like unbounded strings in the same class.

That's not that easy. If you want to restrict the set of code point  
allowed in a container, you must care about preserving class properties. A  
subtype T1 of a type T0, is supposed to be a valid element where a type T0  
is expected. However, if the actual is T1 and the expected type is T0 and  
the object is a target of some operation, then as an example, appending a  
code point outside of the restricted range, while valid with an actual of  
type T0, would be illegal with an actual of type T1. On the contrary, as a  
source T1 will always be valid where a T0 was expected.

Conclusion: the interface could not remain the same, and different  
interface, means different type. Unsolvable (a common pitfall known of  
ancient Eiffel users). That's by the way one of the reason why assertions  
introduced with Ada 2012, are expected to be checked at runtime, because  
to warrant it to be statically valid, would lead to a real nightmare for  
the language maintainers (I keep in mind you don't enjoy runtime check,  
which is OK, if you assume all of the consequences).

> This problem is a *fundamental* problem of the Ada type system. It must  
> be
> addressed if the Ada wishes to stay a strongly typed language.
If address nicely enough (except with some area like String and some part  
of access types) what it provide. Consistency in a narrow range is better  
than a wide range with inconsistencies, and to most people, a narrow range  
which can be reasonably implemented, is better than a perfect thing which  
cannot be implemented. That was one of the error Bertrand Meyer did, when  
he asserted language designers should not bother about whether of not a  
given language property is certain to be implementable. In real life,  
language designers have to care it is, and have to care it is reasonably.

As said in a prior message, such languages already exist, but as far as I  
know, all I played with was either interpreted or inefficient languages  
(and all had names I cannot remember, sorry), which is not OK for Ada (for  
me it's OK if it lacks some purity, as long as it is safe and efficient  
enough).

After all, may be what you need is not Ada! (would not be a shame).

> How so? They are two most used public interfaces of composite types in  
> Ada!
The language does not enforce it, this only occur in the standard library,  
and you remain free to not follow this design and choose your own if you  
wish. Just like the naming convention, I don't enjoy the one of the  
standard package, that does not prevent me from using my own,, the  
language does not enforce anything there.

> BTW the same applies to the numeric types, would you claim them used only
> privately too?
Arguable in theory, not in practice. If it ever is, just use a language  
better suited for your very specific area.


-- 
“Syntactic sugar causes cancer of the semi-colons.”  [Epigrams on  
Programming — Alan J. — P. Yale University]
“Structured Programming supports the law of the excluded muddle.” [Idem]
Java: Write once, Never revisit



  reply	other threads:[~2011-10-21 20:36 UTC|newest]

Thread overview: 100+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2011-10-14  6:58 Why no Ada.Wide_Directories? Michael Rohan
2011-10-14  7:39 ` Yannick Duchêne (Hibou57)
2011-10-14  9:07   ` Dmitry A. Kazakov
2011-10-14 12:48     ` Yannick Duchêne (Hibou57)
2011-10-14 12:54     ` Yannick Duchêne (Hibou57)
2011-10-15  1:06 ` ytomino
2011-10-15  6:55   ` Vadim Godunko
2011-10-15 12:34     ` ytomino
2011-10-15  8:38   ` Dmitry A. Kazakov
2011-10-15 13:12     ` Peter C. Chapin
2011-10-15 13:22       ` Ludovic Brenta
2011-10-15 14:47       ` Dmitry A. Kazakov
2011-10-16  5:48         ` Yannick Duchêne (Hibou57)
2011-10-17  0:15         ` Peter C. Chapin
2011-10-17  3:23           ` Yannick Duchêne (Hibou57)
2011-10-17  7:12           ` Simon Wright
2011-10-17  7:59           ` Dmitry A. Kazakov
2011-10-18 10:55             ` Peter C. Chapin
2011-10-18 12:27               ` Dmitry A. Kazakov
2011-10-16  5:51       ` Yannick Duchêne (Hibou57)
2011-10-17 21:41         ` Randy Brukardt
2011-10-18  7:29           ` Dmitry A. Kazakov
2011-10-18 14:06           ` Pascal Obry
2011-10-18 14:08             ` Pascal Obry
2011-10-19 21:32             ` Randy Brukardt
2011-10-17 21:33   ` Randy Brukardt
2011-10-17 23:47     ` ytomino
2011-10-18  1:10       ` Adam Beneschan
2011-10-18  2:32         ` ytomino
2011-10-18  4:46           ` ytomino
2011-10-18  9:32             ` Yannick Duchêne (Hibou57)
2011-10-18 10:00               ` Dmitry A. Kazakov
2011-10-18 10:06                 ` Yannick Duchêne (Hibou57)
2011-10-18 12:01                   ` Dmitry A. Kazakov
2011-10-18 15:02           ` Adam Beneschan
2011-10-18 15:16             ` Dmitry A. Kazakov
2011-10-18 23:42               ` Adam Beneschan
2011-10-19  8:12                 ` Dmitry A. Kazakov
2011-10-19 21:43               ` Randy Brukardt
2011-10-20  7:37                 ` Dmitry A. Kazakov
2011-10-20 11:04                   ` Yannick Duchêne (Hibou57)
2011-10-20 12:21                     ` Dmitry A. Kazakov
2011-10-20 12:38                       ` Yannick Duchêne (Hibou57)
2011-10-20 14:31                         ` Dmitry A. Kazakov
2011-10-20 15:54                           ` Yannick Duchêne (Hibou57)
2011-10-20 17:35                             ` Dmitry A. Kazakov
2011-10-21 12:53                               ` Yannick Duchêne (Hibou57)
2011-10-21 13:41                                 ` Dmitry A. Kazakov
2011-10-25 19:22                                   ` Randy Brukardt
2011-10-25 19:35                                     ` Dmitry A. Kazakov
2011-10-26 22:41                                       ` Randy Brukardt
2011-10-27  7:43                                         ` Dmitry A. Kazakov
2011-10-27 15:13                                           ` Yannick Duchêne (Hibou57)
2011-10-27 19:39                                             ` Robert A Duff
2011-10-27 21:09                                               ` Yannick Duchêne (Hibou57)
2011-10-28  7:50                                                 ` Dmitry A. Kazakov
2011-10-28  8:45                                                   ` Yannick Duchêne (Hibou57)
2011-10-28 14:59                                                     ` Dmitry A. Kazakov
2011-10-20 17:40                   ` J-P. Rosen
2011-10-20 18:43                     ` Dmitry A. Kazakov
2011-10-21 10:07                     ` Vadim Godunko
2011-10-21 11:25                       ` J-P. Rosen
2011-10-21 12:25                         ` Yannick Duchêne (Hibou57)
2011-10-21 13:13                         ` Dmitry A. Kazakov
2011-10-21 16:03                           ` Yannick Duchêne (Hibou57)
2011-10-21 18:34                             ` Dmitry A. Kazakov
2011-10-21 19:30                               ` Yannick Duchêne (Hibou57)
2011-10-21 20:02                                 ` Dmitry A. Kazakov
2011-10-21 20:36                                   ` Yannick Duchêne (Hibou57) [this message]
2011-10-22  7:54                                     ` Dmitry A. Kazakov
2011-10-22 20:28                                       ` Yannick Duchêne (Hibou57)
2011-10-22 22:23                                       ` Yannick Duchêne (Hibou57)
2011-10-23  7:53                                         ` Dmitry A. Kazakov
2011-10-25 19:16                                           ` Randy Brukardt
2011-10-21 18:55                         ` Vadim Godunko
2011-10-21 19:18                           ` J-P. Rosen
2011-10-21 19:41                           ` Yannick Duchêne (Hibou57)
2011-10-18 22:54             ` ytomino
2011-10-18  3:15         ` Yannick Duchêne (Hibou57)
2011-10-18  7:55         ` Dmitry A. Kazakov
2011-10-18  9:41           ` Yannick Duchêne (Hibou57)
2011-10-18 10:25           ` J-P. Rosen
2011-10-18 10:56             ` Yannick Duchêne (Hibou57)
2011-10-18 15:34           ` Adam Beneschan
2011-10-18 17:27             ` J-P. Rosen
2011-10-18 18:33               ` Adam Beneschan
2011-10-18 19:54               ` Yannick Duchêne (Hibou57)
2011-10-18  8:01       ` Dmitry A. Kazakov
2011-10-18  2:59     ` Yannick Duchêne (Hibou57)
2011-10-18  4:07       ` Michael Rohan
2011-10-18  4:54       ` ytomino
2011-10-18  9:54         ` Yannick Duchêne (Hibou57)
2011-10-18 10:52           ` ytomino
2011-10-18 11:02             ` Yannick Duchêne (Hibou57)
2011-10-18 21:18               ` ytomino
2011-10-18 10:10       ` J-P. Rosen
2011-10-22  6:32         ` Michael Rohan
2011-10-22  7:25           ` Yannick Duchêne (Hibou57)
2011-10-25 19:26           ` Randy Brukardt
2011-10-27 17:40 ` anon
replies disabled

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