From mboxrd@z Thu Jan 1 00:00:00 1970 X-Spam-Checker-Version: SpamAssassin 3.4.4 (2020-01-24) on polar.synack.me X-Spam-Level: X-Spam-Status: No, score=-0.9 required=5.0 tests=BAYES_00,FORGED_GMAIL_RCVD, FREEMAIL_FROM autolearn=no autolearn_force=no version=3.4.4 Path: eternal-september.org!reader01.eternal-september.org!reader02.eternal-september.org!news.eternal-september.org!news.eternal-september.org!news.eternal-september.org!feeder.eternal-september.org!usenet.blueworldhosting.com!feeder01.blueworldhosting.com!peer02.iad.highwinds-media.com!news.highwinds-media.com!feed-me.highwinds-media.com!post02.iad.highwinds-media.com!fx27.iad.POSTED!not-for-mail From: Shark8 User-Agent: Mozilla/5.0 (Windows NT 6.1; Win64; x64; rv:30.0) Gecko/20100101 Thunderbird/30.0a1 MIME-Version: 1.0 Newsgroups: comp.lang.ada Subject: Re: On packages hierarchy References: In-Reply-To: Content-Type: text/plain; charset=ISO-8859-1; format=flowed Content-Transfer-Encoding: 7bit Message-ID: <4vuBv.121143$pu5.79212@fx27.iad> X-Complaints-To: abuse@teranews.com NNTP-Posting-Date: Mon, 28 Jul 2014 16:03:12 UTC Organization: TeraNews.com Date: Mon, 28 Jul 2014 10:03:11 -0600 X-Received-Bytes: 2121 X-Received-Body-CRC: 719665999 Xref: news.eternal-september.org comp.lang.ada:21310 Date: 2014-07-28T10:03:11-06:00 List-Id: On 28-Jul-14 07:41, Victor Porton wrote: > I am going to create the package RDF.Raptor.Iostream which would be Ada > bindings around > http://librdf.org/raptor/api/raptor2-section-iostream.html > > Afterward, I am going to create Ada IO stream (derived from > Root_Stream_Type) which encaspulates (wraps) RDF.Raptor.Iostream and > reversely RDF.Raptor.Iostream which encaspulates (wraps) Root_Stream_Type. > > Should packages which wrap each other be in child packages of > RDF.Raptor.Iostream? I think no, because they do not require access to > internals (private part) of RDF.Raptor.Iostream but child packages have > access to private parts. > > So, should they be siblings, like RDF.Raptor.Iostream_To_Ada and > RDF.Raptor.Iostream_From_Ada? (Also please help to conceive good names for > these packages.) > Er, why? > Streams are a method to read or write any object to any medium, > and thus they are doubly generalized. This also means that you > are bounded by the most restrictive set of operations common to > all mediums. As an example, you cannot provide position control > in a general manner because not all transmission modes are > random-access (like receiving a radio-signal), and not all > streams are bi-directional (like a light-sensor). Why not just have a single stream type? Moreover, Ada's root-stream is abstract, so you can't have objects of that type.