From: "Warren W. Gay VE3WWG" <ve3wwg_nospam@cogeco.ca>
Subject: Re: Modes (was unbounded_string)
Date: Tue, 14 Oct 2003 22:16:48 -0400
Date: 2003-10-14T22:16:48-04:00 [thread overview]
Message-ID: <Mb2jb.8531$Ol.214283@read1.cgocable.net> (raw)
In-Reply-To: rquib.4914$zw4.1688@nwrdny01.gnilink.net
"Stephane Richard" <stephane.richard@verizon.net> wrote in message
news:rquib.4914$zw4.1688@nwrdny01.gnilink.net...
> "Dmitry A. Kazakov" <mailbox@dmitry-kazakov.de> wrote in message
> news:94skovca8efqisiip65q37of63g28n1284@4ax.com...
> > On Fri, 10 Oct 2003 19:06:00 GMT, Jeffrey Carter <spam@spam.com>
> > wrote:
> >
> > >Since GNAT.OS_Lib.Getenv returns type String_Access, you have to use
> > >String_Access if you want to use Getenv. But note the description of
> > >Getenv from GNAT.OS_Lib:
> > >
> > >-- Get the value of the environment variable. Returns an access
> > >-- to the empty string if the environment variable does not exist
> > >-- or has an explicit null value (in some operating systems these
> > >-- are distinct cases, in others they are not; this interface
> > >-- abstracts away that difference. The argument is allocated on
> > >-- the heap (even in the null case), and needs to be freed explicitly
> > >-- when no longer needed to avoid memory leaks.
> >
> > Awful, I didn't expected that from ACT. The design above is definitely
> > not Ada's idiom.
...
> Perhaps as in many OS it's the only way as the OS (probably written in C or
> some other language simply returns it this way?
Well, C returns a pointer, if you use getenv(2). However, there is no reason
that ACT could not have converted this into a normal Ada string, which is
what I would have expected. Even in C, you are really expected to use
putenv or setenv to make a change. However, programmers have been
known to "cheat" and modify the string that the getenv pointer points to,
which works provided that the string does not require more length. But
even in C terms, IMHO, this is a bad practice.
--
Warren W. Gay
http://home.cogeco.ca/~ve3wwg
next prev parent reply other threads:[~2003-10-15 2:16 UTC|newest]
Thread overview: 15+ messages / expand[flat|nested] mbox.gz Atom feed top
[not found] <20031010074015.761204C40C1@lovelace.ada-france.org>
2003-10-10 8:27 ` Modes (was unbounded_string) Andrew Carroll
2003-10-10 9:15 ` Dmitry A. Kazakov
2003-10-11 7:16 ` Simon Wright
2003-10-13 9:28 ` Dmitry A. Kazakov
2003-10-10 15:18 ` Stephen Leake
2003-10-10 16:21 ` Martin Dowie
2003-10-14 18:47 ` Craig Carey
2003-10-10 19:06 ` Jeffrey Carter
2003-10-13 9:33 ` Dmitry A. Kazakov
2003-10-13 9:40 ` Stephane Richard
2003-10-13 10:12 ` Dmitry A. Kazakov
2003-10-15 2:16 ` Warren W. Gay VE3WWG [this message]
2003-10-15 3:36 ` Jeff C,
2003-10-16 16:45 ` Warren W. Gay VE3WWG
[not found] <20031010094017.680474C40C1@lovelace.ada-france.org>
2003-10-10 10:58 ` Andrew Carroll
replies disabled
This is a public inbox, see mirroring instructions
for how to clone and mirror all data and code used for this inbox