comp.lang.ada
 help / color / mirror / Atom feed
From: "Martin Dowie" <martin.dowie@baesystems.com>
Subject: Re: Record representation
Date: Tue, 15 Jun 2004 08:37:19 +0100
Date: 2004-06-15T08:37:19+01:00	[thread overview]
Message-ID: <40cea5f7$1_1@baen1673807.greenlnk.net> (raw)
In-Reply-To: TfGdnTVBHqyzZlrd4p2dnA@megapath.net

"Randy Brukardt" <randy@rrsoftware.com> wrote in message
news:TfGdnTVBHqyzZlrd4p2dnA@megapath.net...
> "Martin Dowie" <martin.dowie@baesystems.com> wrote in message
> news:40c6d3d1$1_1@baen1673807.greenlnk.net...
> > Is there anything that could be done (quickly ;-) by the ARG for Ada200Y
> to
> > do something about this common pain in the *ss?
> >
> > package Record_Rep is
> >
> >    type A is record
> >       I : Integer;
> >    end record;
> >    for A'Size use Integer'Size;
> >
> >    type Index is new Integer range 1 .. 10;
> >
> >    type AA is array (Index) of A;
> >    for AA'Size use A'Size * Index'Last;  -- Not allowed!!!!!
> >
> > end Record_Rep;
> >
> > Surely the language could be made smart enough to support this? This can
> be
> > a real maintenance nightmare to change.
>
> While I've had this problem myself, it occurs mainly because of an abuse
of
> the language (or not trusting compilers to do the right thing). The
> important point is that 'Size on a composite type is not supposed to
change
> the sizes of the components (see 13.3(53)), so it really only can be a
> confirming specification - not very interesting. Hardly worth changing the
> language over.
>
> When I've had this problem, I'll generally declare appropriate constants:


Randy,

Thanks for that - this looks like the pick of the bunch.

It is down to not trusting compilers but the problem I've had at many sites
is coding standards that mandate this practise for always having 'Size
clauses and that are set in stone. :-(

Cheers

-- Martin





      reply	other threads:[~2004-06-15  7:37 UTC|newest]

Thread overview: 13+ messages / expand[flat|nested]  mbox.gz  Atom feed  top
2004-06-09  9:14 Record representation Martin Dowie
2004-06-09 11:38 ` Martin Krischik
2004-06-09 14:11   ` Martin Dowie
2004-06-09 15:30 ` Mark H Johnson
2004-06-09 16:58   ` Martin Dowie
2004-06-09 17:44     ` tmoran
2004-06-09 20:08     ` Mark H Johnson
2004-06-09 21:12       ` Martin Dowie
2004-06-09 21:14       ` Martin Dowie
2004-06-10  0:38 ` Stephen Leake
2004-06-10  6:13   ` Randy Brukardt
2004-06-10  6:10 ` Randy Brukardt
2004-06-15  7:37   ` Martin Dowie [this message]
replies disabled

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