-- Copyright 2020-2023 Free Software Foundation, Inc. -- -- This program is free software; you can redistribute it and/or modify -- it under the terms of the GNU General Public License as published by -- the Free Software Foundation; either version 3 of the License, or -- (at your option) any later version. -- -- This program is distributed in the hope that it will be useful, -- but WITHOUT ANY WARRANTY; without even the implied warranty of -- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -- GNU General Public License for more details. -- -- You should have received a copy of the GNU General Public License -- along with this program. If not, see . with Pck; use Pck; procedure P is type Tag_T is (Unused, Object); type Array_T is array (1 .. Five) of Integer; type Payload_T (Tag : Tag_T := Unused) is record case Tag is when Object => Values : Array_T := (others => 1); when Unused => null; end case; end record; Objects : array (1 .. 2) of Payload_T; type Another_Type (Tag : Tag_T := Unused) is record case Tag is when Unused => CVal : Character; when Object => IVal : Integer; end case; end record; type Enclosing is record Initial : Integer; Rest : Another_Type; end record; Another_Array : array (1 .. 2) of Enclosing := ((Initial => 0, Rest => (Tag => Unused, CVal => 'X')), (Initial => 0, Rest => (Tag => Object, IVal => 88))); begin Objects (1) := (Tag => Object, Values => (others => 2)); Do_Nothing (Objects'Address); -- START Do_Nothing (Another_Array'Address); end P;