WITH REPORT; USE REPORT;
PROCEDURE C43204H IS
TYPE ARR11 IS ARRAY (INTEGER RANGE -3 .. 3) OF INTEGER;
TYPE ARR12 IS ARRAY (IDENT_INT(-3) .. IDENT_INT(3)) OF INTEGER;
TYPE ARR13 IS ARRAY (IDENT_INT(1) .. IDENT_INT(-1)) OF INTEGER;
TYPE ARR21 IS ARRAY (INTEGER RANGE -1 .. 1,
INTEGER RANGE -1 .. 1) OF INTEGER;
TYPE ARR22 IS ARRAY (IDENT_INT(-1) .. IDENT_INT(1),
IDENT_INT(-1) .. IDENT_INT(1)) OF INTEGER;
TYPE ARR23 IS ARRAY (INTEGER RANGE -1 .. 1,
IDENT_INT(-1) .. IDENT_INT(1)) OF INTEGER;
TYPE ARR24 IS ARRAY (IDENT_INT(1) .. IDENT_INT(-1),
IDENT_INT(-1) .. IDENT_INT(1)) OF INTEGER;
GENERIC
GA11 : ARR11 := (1,1,1,1,1, OTHERS => IDENT_INT(2));
GA12 : ARR12 := (OTHERS => IDENT_INT(2));
GA13 : ARR13 := (OTHERS => IDENT_INT(2));
GA21 : ARR21 := ((1,1,1), (1,1,1), (OTHERS => IDENT_INT(2)));
GA22 : ARR22 := ((1,1,1), (OTHERS => IDENT_INT(2)), (1,1,1));
GA23 : ARR23 := ((1,1,1), (OTHERS => IDENT_INT(2)), (1,1,1));
GA24 : ARR24 := (OTHERS => (OTHERS => IDENT_INT(2)));
PROCEDURE GEN;
PROCEDURE GEN IS
BEGIN
IF GA11 /= (1, 1, 1, 1, 1, 2, 2) THEN
FAILED("INCORRECT VALUE OF GA11");
END IF;
IF GA12 /= (2, 2, 2, 2, 2, 2, 2) THEN
FAILED("INCORRECT VALUE OF GA12");
END IF;
IF GA13'LENGTH /= 0 THEN
FAILED("INCORRECT VALUE OF GA13");
END IF;
IF GA21 /= ((1,1,1), (1,1,1), (2,2,2)) THEN
FAILED("INCORRECT VALUE OF GA21");
END IF;
IF GA22 /= ((1,1,1), (2,2,2), (1,1,1)) THEN
FAILED("INCORRECT VALUE OF GA22");
END IF;
IF GA23 /= ((1,1,1), (2,2,2), (1,1,1)) THEN
FAILED("INCORRECT VALUE OF GA23");
END IF;
IF GA24'LENGTH /= 0 OR GA24'LENGTH(2) /= 3 THEN
FAILED("INCORRECT VALUE OF GA24");
END IF;
END GEN;
PROCEDURE PROCG IS NEW GEN;
BEGIN
TEST ("C43204H", "CHECK THAT AN AGGREGATE WITH AN OTHERS CLAUSE " &
"CAN APPEAR AS A CONSTRAINED FORMAL PARAMETER " &
"OF A GENERIC UNIT, AND THAT THE BOUNDS OF " &
"THE AGGREGATE ARE DETERMINED CORRECTLY");
PROCG;
RESULT;
EXCEPTION
WHEN OTHERS =>
FAILED ("UNEXPECTED CONSTRAINT_ERROR OR OTHER EXCEPTION " &
"RAISED");
RESULT;
END C43204H;