3.10.1 Incomplete Type Declarations
There are no particular limitations on the designated
type of an access type. In particular, the type of a component of the
designated type can be another access type, or even the same access type.
This permits mutually dependent and recursive access types. An
incomplete_type_declaration
can be used to introduce a type to be used as a designated type, while
deferring its full definition to a subsequent
full_type_declaration.
Syntax
Static Semantics
An
incomplete_type_declaration
declares an
incomplete view of a type and its first subtype; the
first subtype is unconstrained if a
discriminant_part
appears. If the
incomplete_type_declaration
includes the reserved word
tagged, it declares a
tagged incomplete
view.
If
T denotes
a tagged incomplete view, then
T'Class denotes a tagged incomplete
view. An incomplete view of a type is a limited view of the type (see
7.5).
Given an access type
A whose designated type T is an incomplete view, a dereference
of a value of type A also has this incomplete view except when:
it occurs within the immediate scope of the completion
of T, or
it occurs within the scope of a
nonlimited_with_clause
that mentions a library package in whose visible part the completion
of
T is declared, or
In these cases, the dereference has the view of
T visible at the point of the dereference.
Similarly, if a
subtype_mark
denotes a
subtype_declaration
defining a subtype of an incomplete view
T, the
subtype_mark
denotes an incomplete view except under the same three circumstances
given above, in which case it denotes the view of
T visible at
the point of the
subtype_mark.
Legality Rules
A
name
that denotes an incomplete view of a type may be used as follows:
as a generic actual parameter whose corresponding
generic formal parameter is a formal incomplete type (see
12.5.1).
If such a
name
denotes a tagged incomplete view, it may also be used:
This
paragraph was deleted.
This paragraph
was deleted.
If any of the above uses occurs as part of the declaration
of a primitive subprogram of the incomplete view, and the declaration
occurs immediately within the private part of a package, then the completion
of the incomplete view shall also occur immediately within the private
part; it shall not be deferred to the package body.
No other uses of a
name
that denotes an incomplete view of a type are allowed.
A
prefix
that denotes an object shall not be of an incomplete view. An actual
parameter in a call shall not be of an untagged incomplete view. The
result object of a function call shall not be of an incomplete view.
A
prefix shall
not denote a subprogram having a formal parameter of an untagged incomplete
view, nor a return type that is an incomplete view.
The controlling operand or controlling result of
a dispatching call shall not be of an incomplete view if the operand
or result is dynamically tagged.
Paragraph 11 was
deleted.
Dynamic Semantics
NOTE 2 A
name
that denotes an object of an incomplete view is defined to be of a limited
type. Hence, the target of an assignment statement cannot be of an incomplete
view.
Examples
Example of a recursive
type:
type Cell; -- incomplete type declaration
type Link is access Cell;
type Cell is
record
Value : Integer;
Succ : Link;
Pred : Link;
end record;
Head : Link := new Cell'(0, null, null);
Next : Link := Head.Succ;
Examples of mutually dependent access types:
type Person(<>); -- incomplete type declaration
type Car is tagged; -- incomplete type declaration
type Person_Name is access Person;
type Car_Name is access all Car'Class;
type Car is tagged
record
Number : Integer;
Owner : Person_Name;
end record;
type Person(Sex : Gender) is
record
Name : String(1 .. 20);
Birth : Date;
Age : Integer range 0 .. 130;
Vehicle : Car_Name;
case Sex is
when M => Wife : Person_Name(Sex => F);
when F => Husband : Person_Name(Sex => M);
end case;
end record;
My_Car, Your_Car, Next_Car : Car_Name :=
new Car; --
see 4.8
Casey : Person_Name :=
new Person(M);
...
Casey.Vehicle := Your_Car;
Ada 2005 and 2012 Editions sponsored in part by Ada-Europe