WITH REPORT;
PROCEDURE C48005A IS
USE REPORT;
BEGIN
TEST("C48005A","CHECK THAT THE FORM 'NEW T X' ALLOCATES A " &
"NEW OBJECT AND THAT IF T IS AN UNCONSTRAINED " &
"RECORD, PRIVATE, OR LIMITED TYPE, THE " &
"ALLOCATED OBJECT HAS THE DISCRIMINANT " &
"VALUES SPECIFIED BY X");
DECLARE
TYPE UR1(A : INTEGER) IS
RECORD
B : INTEGER := 7;
C : INTEGER := 4;
END RECORD;
TYPE UR2(A : INTEGER) IS
RECORD
CASE A IS
WHEN 1 =>
A1 : INTEGER := 4;
WHEN 2 =>
A2 : INTEGER := 5;
WHEN OTHERS =>
NULL;
END CASE;
END RECORD;
TYPE A_UR1 IS ACCESS UR1;
TYPE A_UR2 IS ACCESS UR2;
V1AUR1 : A_UR1;
V1AUR2, V2AUR2 : A_UR2;
TYPE REC (A : INTEGER) IS
RECORD
B : INTEGER;
END RECORD;
TYPE A_REC IS ACCESS REC;
V_A_REC : A_REC;
TYPE ARR IS ARRAY(1 .. 1) OF INTEGER;
TYPE RECVAL IS
RECORD
A : INTEGER;
B : ARR;
END RECORD;
FUNCTION FUN (A : INTEGER) RETURN INTEGER IS
BEGIN
RETURN IDENT_INT(A);
END FUN;
FUNCTION FUN (A : INTEGER) RETURN RECVAL IS
BEGIN
FAILED ("WRONG OVERLOADED FUNCTION CALLED");
RETURN (1, (1 => 2));
END FUN;
BEGIN
V1AUR1 := NEW UR1(3);
IF ( V1AUR1.A /= 3 OR V1AUR1.B /= 7 OR
V1AUR1.C /= IDENT_INT(4) ) THEN
FAILED("WRONG VALUES - V1UAR1");
END IF;
V1AUR2 := NEW UR2(IDENT_INT(2));
IF ( V1AUR2.A /= 2 OR V1AUR2.A2 /= IDENT_INT(5) ) THEN
FAILED("WRONG VALUES - V1AUR2");
END IF;
V2AUR2 := NEW UR2(IDENT_INT(3));
IF ( V2AUR2.A /= IDENT_INT(3) ) THEN
FAILED("WRONG VALUES - V2AUR2");
END IF;
V_A_REC := NEW REC(FUN(2));
END;
RESULT;
END C48005A;