WITH REPORT; USE REPORT;
PROCEDURE C32001C IS
TYPE ARR IS ARRAY (1 .. 2) OF INTEGER;
F1, G1 : ARR;
BUMP : ARR := (0, 0);
FUNCTION F (I : INTEGER) RETURN INTEGER IS
BEGIN
BUMP (I) := BUMP(I) + 1;
F1 (I) := BUMP (I);
RETURN BUMP (I);
END F;
FUNCTION G (I : INTEGER) RETURN INTEGER IS
BEGIN
BUMP (I) := BUMP(I) + 1;
G1 (I) := BUMP (I);
RETURN BUMP (I);
END G;
FUNCTION H (I : INTEGER) RETURN INTEGER IS
BEGIN
BUMP (I) := BUMP(I) + 1;
RETURN BUMP (I);
END H;
BEGIN
TEST ("C32001C", "CHECK THAT IN MULTIPLE OBJECT DECLARATIONS " &
"FOR RECORD TYPES, THE SUBTYPE INDICATION " &
"AND THE INITIALIZATION EXPRESSIONS ARE " &
"EVALUATED ONCE FOR EACH NAMED OBJECT THAT " &
"IS DECLARED AND THE SUBTYPE INDICATION IS " &
"EVALUATED FIRST. ALSO, CHECK THAT THE " &
"EVALUATIONS YIELD THE SAME RESULT AS A " &
"SEQUENCE OF SINGLE OBJECT DECLARATIONS" );
DECLARE
TYPE REC (D1, D2 : INTEGER) IS
RECORD
VALUE : INTEGER;
END RECORD;
R1, R2 : REC (F (1), G (1)) :=
(F1 (1), G1 (1), VALUE => H (1));
CR1, CR2 : CONSTANT REC (F (2), G (2)) :=
(F1 (2), G1 (2), VALUE => H (2));
PROCEDURE CHECK
(R : REC; V1, V2, VAL : INTEGER; S : STRING) IS
BEGIN
IF R.D1 = V1 THEN
IF R.D2 = V2 THEN
COMMENT ( S & ".D1 INITIALIZED TO " &
INTEGER'IMAGE (V1) & " AND " &
S & ".D2 INITIALIZED TO " &
INTEGER'IMAGE (V2));
ELSE
FAILED ( S &
".D2 INITIALIZED INCORRECTLY - 1" );
END IF;
ELSIF R.D1 = V2 THEN
IF R.D2 =V1 THEN
COMMENT ( S & ".D1 INITIALIZED TO " &
INTEGER'IMAGE (V2) & " AND " &
S & ".D2 INITIALIZED TO " &
INTEGER'IMAGE (V1));
ELSE
FAILED ( S &
".D2 INITIALIZED INCORRECTLY - 2" );
END IF;
ELSE
FAILED ( S & ".D1 INITIALIZED INCORRECTLY TO " &
INTEGER'IMAGE (R.D1) );
END IF;
IF R.VALUE /= VAL THEN
FAILED ( S & ".VALUE INITIALIZED INCORRECTLY" );
END IF;
END CHECK;
BEGIN
CHECK (R1, 1, 2, 3, "R1");
CHECK (R2, 4, 5, 6, "R2");
CHECK (CR1, 1, 2, 3, "CR1");
CHECK (CR2, 4, 5, 6, "CR2");
END;
RESULT;
END C32001C;