From: Tucker Taft <stt@averstar.com>
Subject: Re: Generics and parameter modes
Date: 1999/08/17
Date: 1999-08-17T00:00:00+00:00 [thread overview]
Message-ID: <37B991F7.79D30959@averstar.com> (raw)
In-Reply-To: 37B85F88.C87638C4@dowie-cs.demon.co.uk
Martin Dowie wrote:
>
> i have an instance of a package similar to the generic listed below.
> when calling the 'size' routine the actual parameter is passed by copy
> and not by reference as i had expected. this is really annoying as the
> data object is a few hundred kbytes in size! is there anything in Ada95
> that allows/requires this?
Non-limited, non-tagged record types may be passed either by reference
or by copy. On the other hand, I am quite surprised that a compiler
would go out of its way to pass such a large object by copy, since it
requires more work. The only reasons I can imagine for doing this are:
1) the compiler is trying to enable more generic code sharing
(but that seems a bit far-fetched, since even in a shared
generic it "knows" a_list is a record type);
2) there is some kind of alignment problem, where the actual parameter
is not properly aligned for the code inside the generic (again
a bit far-fetched);
3) the actual parameter is marked volatile or atomic (see RM95 C.6(19));
4) convention C_Pass_By_Copy applies to the type (I don't see such
a pragma below);
5) the compiler has a bug ;-).
Are you really sure that it is passing the parameter by copy? I would
contact Rational and file a lousy-code-quality-but-not-quite-a-bug report.
> generic
> type an_item is private;
> maximum_number_of_items : positive;
> package generic_list is
> subtype a_number_of_items is natural range 0 ..
> maximum_number_of_items;
> subtype an_item_index is natural range 1 .. maximum_number_of_items;
>
> type a_list is private;
> -- Lots of other stuff...
> function size (list : in a_list) return a_number_of_items;
> private
> type an_array_of_items is array (an_item_index) of an_item;
> type a_list is record
> current_size, current_item : a_number_of_items;
> items : an_array_of_items;
> end record;
> end generic_list;
>
> the type used in the declaration is a variant record which it self
> contains variant fields within a number of the variant branches (approx.
> 300 bytes storage required).
>
> i'm using Rational Apex v3 and have tried a mini version at home (using
> the above) and ObjectAda seems to pass it by reference (not 100% on this
> as my Intel assembler knowledge is zilch!).
ObjectAda would pass such an object by reference unless the actual
were misaligned (maladjusted? ;-), marked atomic or volatile, or had
a C_Pass_By_Copy convention.
--
-Tucker Taft stt@averstar.com http://www.averstar.com/~stt/
Technical Director, Distributed IT Solutions (www.averstar.com/tools)
AverStar (formerly Intermetrics, Inc.) Burlington, MA USA
next prev parent reply other threads:[~1999-08-17 0:00 UTC|newest]
Thread overview: 6+ messages / expand[flat|nested] mbox.gz Atom feed top
1999-08-16 0:00 Generics and parameter modes Martin Dowie
1999-08-17 0:00 ` Tucker Taft [this message]
1999-08-21 0:00 ` Martin Dowie
1999-08-21 0:00 ` Robert Dewar
1999-08-21 0:00 ` Martin Dowie
1999-08-17 0:00 ` 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