aboutsummaryrefslogtreecommitdiff
path: root/gcc/testsuite/ada/acats/tests/c9/c940011.a
diff options
context:
space:
mode:
Diffstat (limited to 'gcc/testsuite/ada/acats/tests/c9/c940011.a')
-rw-r--r--gcc/testsuite/ada/acats/tests/c9/c940011.a175
1 files changed, 0 insertions, 175 deletions
diff --git a/gcc/testsuite/ada/acats/tests/c9/c940011.a b/gcc/testsuite/ada/acats/tests/c9/c940011.a
deleted file mode 100644
index 65228666cd3..00000000000
--- a/gcc/testsuite/ada/acats/tests/c9/c940011.a
+++ /dev/null
@@ -1,175 +0,0 @@
--- C940011.A
---
--- 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.
---*
---
--- OBJECTIVE:
--- Check that, in the body of a protected object created by the execution
--- of an allocator, external calls to other protected objects via
--- the access type are correctly performed
---
--- TEST DESCRIPTION:
--- Use a subset of the simulation of the freeway on-ramp described in
--- c940005. In this case an array of access types is built with pointers
--- to successive ramps. The external calls within the protected
--- objects are made via the index into the array. Routines which refer
--- to the "previous" ramp and the "next" ramp are exercised. (Note: The
--- first and last ramps are assumed to be dummies and no first/last
--- condition code is included)
---
---
--- CHANGE HISTORY:
--- 06 Dec 94 SAIC ACVC 2.0
---
---!
-
-
-with Report;
-
-
-procedure C940011 is
-
- type Ramp;
- type acc_Ramp is access Ramp;
-
- subtype Ramp_Index is integer range 1..4;
-
-
- -- Weighted load given to each potential problem area and accumulated
- type Load_Factor is range 0..8;
- Clear_Level : constant Load_Factor := 0;
- Moderate_Level : constant Load_Factor := 3;
-
- --================================================================
- -- Only the Routines that are used in this test are shown
- --
- protected type Ramp is
-
- procedure Set_Index (Index : Ramp_Index);
- procedure Set_Local_Overload (Sensor_Level : Load_Factor);
- function Local_Overload return Load_Factor;
- procedure Notify;
- function Next_Ramp_Overload return Load_Factor;
-
- private
-
- This_Ramp : Ramp_Index;
-
- Next_Ramp_Alert : Boolean := false; -- Next Ramp is in trouble?
-
- -- Current state of the various Sample Points
- Local_State : Load_Factor := Clear_Level;
-
- end Ramp;
- --================================================================
-
- -- Build a set of Ramp objects and an array of pointers to them
- --
- Ramp_Array : array (Ramp_Index) of acc_Ramp := (Ramp_Index => new Ramp);
-
- --================================================================
- protected body Ramp is
-
- procedure Set_Index (Index : Ramp_Index) is
- begin
- This_Ramp := Index;
- end Set_Index;
-
- -- These Set/Clear routines are triggered by real-time sensors that
- -- reflect traffic state
- procedure Set_Local_Overload(Sensor_Level : Load_Factor) is
- begin
- if Local_State = Clear_Level then
- -- Notify "previous" ramp to check this one for current state.
- -- Subsequent changes in state will not send an alert
- -- When the situation clears another routine performs the
- -- all_clear notification. (not shown)
- -- EXTERNAL CALL OF PROCEDURE FROM PROCEDURE
- Ramp_Array(This_Ramp - 1).Notify; -- index to previous ramp
- end if;
- Local_State := Sensor_Level;
- null; --::::: Start local meter if not already started
- end Set_Local_Overload;
-
- function Local_Overload return Load_Factor is
- begin
- return Local_State;
- end Local_Overload;
-
- -- This is notification from the next ramp that it is in
- -- overload. With this provision we only need to sample the next
- -- ramp during adverse conditions.
- procedure Notify is
- begin
- Next_Ramp_Alert := true;
- end Notify;
-
- function Next_Ramp_Overload return Load_Factor is
- begin
- if Next_Ramp_Alert then
- -- EXTERNAL FUNCTION CALL FROM FUNCTION
- -- Get next ramp's current state
- return Ramp_Array(This_Ramp + 1).Local_Overload;
- else
- return Clear_Level;
- end if;
- end Next_Ramp_Overload;
- end Ramp;
-
- --================================================================
-
-
-begin
-
-
- Report.Test ("C940011", "Protected Objects created by allocators: " &
- "external calls via access types");
-
- -- Initialize each Ramp
- for i in Ramp_Index loop
- Ramp_Array(i).Set_Index (i);
- end loop;
-
- -- Test driver. This is ALL test control code
-
- -- Simulate calls to the protected functions and procedures
- -- external calls. (do not call the "dummy" end ramps)
-
- -- Simple Call
- if Ramp_Array(2).Next_Ramp_Overload /= Clear_level then
- Report.Failed ("Primary call incorrect");
- end if;
-
- -- Call which results in an external procedure call via the array
- -- index from within the protected object
- Ramp_Array(3).Set_Local_Overload (Moderate_Level);
-
- -- Call which results in an external function call via the array
- -- index from within the protected object
- if Ramp_Array(2).Next_Ramp_Overload /= Moderate_level then
- Report.Failed ("Secondary call incorrect");
- end if;
-
- Report.Result;
-
-end C940011;