blob: 48dced34e55ded89705740eabc57a4600dd95737 [file] [log] [blame]
-- C93003A.ADA
-- Grant of Unlimited Rights
--
-- Under contracts F33600-87-D-0337, F33600-84-D-0280, MDA903-79-C-0687,
-- F08630-91-C-0015, and DCA100-97-D-0025, the U.S. Government obtained
-- unlimited rights in the software and documentation contained herein.
-- Unlimited rights are defined in DFAR 252.227-7013(a)(19). By making
-- this public release, the Government intends to confer upon all
-- recipients unlimited rights equal to those held by the Government.
-- These rights include rights to use, duplicate, release or disclose the
-- released technical data and computer software in whole or in part, in
-- any manner and for any purpose whatsoever, and to have or permit others
-- to do so.
--
-- DISCLAIMER
--
-- ALL MATERIALS OR INFORMATION HEREIN RELEASED, MADE AVAILABLE OR
-- DISCLOSED ARE AS IS. THE GOVERNMENT MAKES NO EXPRESS OR IMPLIED
-- WARRANTY AS TO ANY MATTER WHATSOEVER, INCLUDING THE CONDITIONS OF THE
-- SOFTWARE, DOCUMENTATION OR OTHER INFORMATION RELEASED, MADE AVAILABLE
-- OR DISCLOSED, OR THE OWNERSHIP, MERCHANTABILITY, OR FITNESS FOR A
-- PARTICULAR PURPOSE OF SAID MATERIAL.
--*
-- CHECK THAT ACTIVATION OF TASKS CREATED BY ALLOCATORS PRESENT IN A
-- DECLARATIVE PART TAKES PLACE DURING ELABORATION OF THE
-- CORRESPONDING DECLARATION.
-- SUBTESTS ARE:
-- (A) A SIMPLE TASK ALLOCATOR, IN A BLOCK.
-- (B) AN ARRAY OF TASK ALLOCATOR, IN A FUNCTION.
-- (C) A RECORD OF TASK ALLOCATOR, IN A PACKAGE SPECIFICATION.
-- (D) A RECORD OF ARRAY OF TASK ALLOCATOR, IN A PACKAGE BODY.
-- (E) AN ARRAY OF RECORD OF TASK ALLOCATOR, IN A TASK BODY.
-- JRK 9/28/81
-- SPS 11/11/82
-- SPS 11/21/82
-- RJW 8/4/86 ADDED CHECKS ON INITIALIZATIONS OF NON-TASK COMPONENTS
-- OF RECORD TYPES.
-- PWN 11/30/94 REMOVED PRAGMA PRIORITY INSTANCES FOR ADA 9X.
WITH REPORT; USE REPORT;
WITH SYSTEM; USE SYSTEM;
PROCEDURE C93003A IS
GLOBAL : INTEGER;
FUNCTION SIDE_EFFECT (I : INTEGER) RETURN INTEGER IS
BEGIN
GLOBAL := IDENT_INT (I);
RETURN 0;
END SIDE_EFFECT;
TASK TYPE TT IS
ENTRY E;
END TT;
TASK BODY TT IS
I : INTEGER := SIDE_EFFECT (1);
BEGIN
NULL;
END TT;
BEGIN
TEST ("C93003A", "CHECK THAT ACTIVATION OF TASKS CREATED BY " &
"ALLOCATORS PRESENT IN A DECLARATIVE PART " &
"TAKES PLACE DURING ELABORATION OF THE " &
"CORRESPONDING DECLARATION");
--------------------------------------------------
GLOBAL := IDENT_INT (0);
DECLARE -- (A)
TYPE A IS ACCESS TT;
T1 : A := NEW TT;
I1 : INTEGER := GLOBAL;
J : INTEGER := SIDE_EFFECT (0);
T2 : A := NEW TT;
I2 : INTEGER := GLOBAL;
BEGIN -- (A)
IF I1 /= 1 OR I2 /= 1 THEN
FAILED ("A SIMPLE TASK ALLOCATOR IN A BLOCK WAS " &
"ACTIVATED TOO LATE - (A)");
END IF;
END; -- (A)
--------------------------------------------------
GLOBAL := IDENT_INT (0);
DECLARE -- (B)
J : INTEGER;
FUNCTION F RETURN INTEGER IS
TYPE A_T IS ARRAY (1 .. 1) OF TT;
TYPE A IS ACCESS A_T;
A1 : A := NEW A_T;
I1 : INTEGER := GLOBAL;
J : INTEGER := SIDE_EFFECT (0);
A2 : A := NEW A_T;
I2 : INTEGER := GLOBAL;
BEGIN
IF I1 /= 1 OR I2 /= 1 THEN
FAILED ("AN ARRAY OF TASK ALLOCATOR IN A " &
"FUNCTION WAS ACTIVATED TOO LATE - (B)");
END IF;
RETURN 0;
END F;
BEGIN -- (B)
J := F ;
END; -- (B)
--------------------------------------------------
GLOBAL := IDENT_INT (0);
DECLARE -- (C1)
PACKAGE P IS
TYPE INTREC IS
RECORD
N1 : INTEGER := GLOBAL;
END RECORD;
TYPE RT IS
RECORD
M : INTEGER := GLOBAL;
T : TT;
N : INTREC;
END RECORD;
TYPE A IS ACCESS RT;
R1 : A := NEW RT;
I1 : INTEGER := GLOBAL;
J : INTEGER := SIDE_EFFECT (0);
R2 : A := NEW RT;
I2 : INTEGER := GLOBAL;
END P;
BEGIN -- (C1)
IF P.R1.M /= 0 OR P.R1.N.N1 /= 0 THEN
FAILED ("NON-TASK COMPONENTS OF RECORD R1 NOT " &
"INITIALIZED BEFORE TASK ACTIVATED - (C1)" );
END IF;
IF P.R2.M /= 0 OR P.R2.N.N1 /= 0 THEN
FAILED ("NON-TASK COMPONENTS OF RECORD R2 NOT " &
"INITIALIZED BEFORE TASK ACTIVATED - (C1)" );
END IF;
IF P.I1 /= 1 OR P.I2 /= 1 THEN
FAILED ("A RECORD OF TASK ALLOCATOR IN A PACKAGE " &
"SPECIFICATION WAS ACTIVATED TOO LATE - (C1)");
END IF;
END; -- (C1)
--------------------------------------------------
GLOBAL := IDENT_INT (0);
DECLARE -- (C2)
PACKAGE Q IS
J1 : INTEGER;
PRIVATE
TYPE GRADE IS (GOOD, FAIR, POOR);
TYPE REC (G : GRADE) IS
RECORD
NULL;
END RECORD;
TYPE ACCR IS ACCESS REC;
TYPE ACCI IS ACCESS INTEGER;
TYPE RT IS
RECORD
M : ACCR := NEW REC (GRADE'VAL (GLOBAL));
T : TT;
N : ACCI := NEW INTEGER'(GLOBAL);
END RECORD;
TYPE A IS ACCESS RT;
R1 : A := NEW RT;
I1 : INTEGER := GLOBAL;
J2 : INTEGER := SIDE_EFFECT (0);
R2 : A := NEW RT;
I2 : INTEGER := GLOBAL;
END Q;
PACKAGE BODY Q IS
BEGIN
IF R1.M.G /= GOOD OR R1.N.ALL /= 0 THEN
FAILED ("NON-TASK COMPONENTS OF RECORD R1 NOT " &
"INITIALIZED BEFORE TASK ACTIVATED " &
"- (C2)" );
END IF;
IF R2.M.G /= GOOD OR R2.N.ALL /= 0 THEN
FAILED ("NON-TASK COMPONENTS OF RECORD R2 NOT " &
"INITIALIZED BEFORE TASK ACTIVATED " &
"- (C2)" );
END IF;
IF I1 /= 1 OR I2 /= 1 THEN
FAILED ("A RECORD OF TASK ALLOCATOR IN A PACKAGE " &
"SPECIFICATION WAS ACTIVATED TOO LATE " &
"- (C2)");
END IF;
END Q;
BEGIN -- (C2)
NULL;
END; -- (C2)
--------------------------------------------------
GLOBAL := IDENT_INT (0);
DECLARE -- (D)
PACKAGE P IS
TYPE ARR IS ARRAY (1 .. 1) OF TT;
TYPE INTARR IS ARRAY (1 .. 1) OF INTEGER;
TYPE RAT IS
RECORD
M : INTARR := (1 => GLOBAL);
A : ARR;
N : INTARR := (1 => GLOBAL);
END RECORD;
END P;
PACKAGE BODY P IS
TYPE A IS ACCESS RAT;
RA1 : A := NEW RAT;
I1 : INTEGER := GLOBAL;
J : INTEGER := SIDE_EFFECT (0);
RA2 : A := NEW RAT;
I2 : INTEGER := GLOBAL;
BEGIN
IF RA1.M (1) /= 0 OR RA1.N (1) /= 0 THEN
FAILED ("NON-TASK COMPONENTS OF RECORD RA1 NOT " &
"INITIALIZED BEFORE TASK ACTIVATED " &
"- (D)" );
END IF;
IF RA2.M (1) /= 0 OR RA2.N (1) /= 0 THEN
FAILED ("NON-TASK COMPONENTS OF RECORD RA2 NOT " &
"INITIALIZED BEFORE TASK ACTIVATED " &
"- (D)" );
END IF;
IF I1 /= 1 OR I2 /= 1 THEN
FAILED ("A RECORD OF ARRAY OF TASK ALLOCATOR IN " &
"A PACKAGE BODY WAS ACTIVATED " &
"TOO LATE - (D)");
END IF;
END P;
BEGIN -- (D)
NULL;
END; -- (D)
--------------------------------------------------
GLOBAL := IDENT_INT (0);
DECLARE -- (E)
TASK T IS
ENTRY E;
END T;
TASK BODY T IS
TYPE RT IS
RECORD
M : BOOLEAN := BOOLEAN'VAL (GLOBAL);
T : TT;
N : CHARACTER := CHARACTER'VAL (GLOBAL);
END RECORD;
TYPE ART IS ARRAY (1 .. 1) OF RT;
TYPE A IS ACCESS ART;
AR1 : A := NEW ART;
I1 : INTEGER := GLOBAL;
J : INTEGER := SIDE_EFFECT (0);
AR2 : A := NEW ART;
I2 : INTEGER := GLOBAL;
BEGIN
IF AR1.ALL (1).M /= FALSE OR
AR1.ALL (1).N /= ASCII.NUL THEN
FAILED ("NON-TASK COMPONENTS OF RECORD AR1 NOT " &
"INITIALIZED BEFORE TASK ACTIVATED " &
"- (E)" );
END IF;
IF AR2.ALL (1).M /= FALSE OR
AR2.ALL (1).N /= ASCII.NUL THEN
FAILED ("NON-TASK COMPONENTS OF RECORD AR2 NOT " &
"INITIALIZED BEFORE TASK ACTIVATED " &
"- (E)" );
END IF;
IF I1 /= 1 OR I2 /= 1 THEN
FAILED ("AN ARRAY OF RECORD OF TASK ALLOCATOR IN " &
"A TASK BODY WAS ACTIVATED TOO LATE - (E)");
END IF;
END T;
BEGIN -- (E)
NULL;
END; -- (E)
--------------------------------------------------
RESULT;
END C93003A;