c37403a.ada
来自「linux下编程用 编译软件」· ADA 代码 · 共 187 行
ADA
187 行
-- C37403A.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 WHEN A FORMAL PARAMETER OF A SUBPROGRAM, ENTRY, OR -- GENERIC UNIT HAS AN UNCONSTRAINED TYPE WITH DISCRIMINANTS THAT DO -- NOT HAVE DEFAULTS, 'CONSTRAINED IS 'TRUE' REGARDLESS OF THE MODE -- OF THE PARAMETER.-- R.WILLIAMS 9/1/86WITH REPORT; USE REPORT;PROCEDURE C37403A ISBEGIN TEST ( "C37403A", "CHECK THAT WHEN A FORMAL PARAMETER OF A " & "SUBPROGRAM, ENTRY, OR GENERIC UNIT HAS AN " & "UNCONSTRAINED TYPE WITH DISCRIMINANTS THAT " & "DO NOT HAVE DEFAULTS, 'CONSTRAINED IS " & "'TRUE' REGARDLESS OF THE MODE OF THE " & "PARAMETER" ); DECLARE SUBTYPE INT IS INTEGER RANGE 1.. 10; TYPE MATRIX IS ARRAY (INT RANGE <>, INT RANGE <>) OF INTEGER; TYPE SQUARE (SIDE : INT) IS RECORD MAT : MATRIX (1 .. SIDE, 1 .. SIDE); END RECORD; S1 : SQUARE (2) := (2, ((1, 2), (3, 4))); S2 : SQUARE (2) := S1; S3 : SQUARE (2); SC : CONSTANT SQUARE := (SIDE => 1, MAT => (1 => (1 => 1))); PROCEDURE P (PIN1, PIN2 : IN SQUARE; PINOUT : IN OUT SQUARE; POUT : OUT SQUARE) IS BEGIN IF PIN1'CONSTRAINED THEN NULL; ELSE FAILED ( "'CONSTRAINED IS 'FALSE' FOR OBJECT " & "OF IN MODE - 1" ); END IF; IF PIN2'CONSTRAINED THEN NULL; ELSE FAILED ( "'CONSTRAINED IS 'FALSE' FOR OBJECT " & "OF IN MODE - 2" ); END IF; IF PINOUT'CONSTRAINED THEN NULL; ELSE FAILED ( "'CONSTRAINED IS 'FALSE' FOR " & "OBJECT OF IN OUT MODE - 1" ); END IF; IF POUT'CONSTRAINED THEN NULL; ELSE FAILED ( "'CONSTRAINED IS 'FALSE' FOR " & "OBJECT OF OUT MODE - 1" ); END IF; POUT := (2, ((1, 2), (3, 4))); END P; TASK T IS ENTRY Q (PIN1, PIN2 : IN SQUARE; PINOUT : IN OUT SQUARE; POUT : OUT SQUARE); END T; TASK BODY T IS BEGIN ACCEPT Q (PIN1, PIN2 : IN SQUARE; PINOUT : IN OUT SQUARE; POUT : OUT SQUARE) DO BEGIN IF PIN1'CONSTRAINED THEN NULL; ELSE FAILED ( "'CONSTRAINED IS 'FALSE' FOR " & "OBJECT OF IN MODE - 3" ); END IF; IF PIN2'CONSTRAINED THEN NULL; ELSE FAILED ( "'CONSTRAINED IS 'FALSE' FOR " & "OBJECT OF IN MODE - 4" ); END IF; IF PINOUT'CONSTRAINED THEN NULL; ELSE FAILED ( "'CONSTRAINED IS 'FALSE' FOR " & "OBJECT OF " & "IN OUT MODE - 2" ); END IF; IF POUT'CONSTRAINED THEN NULL; ELSE FAILED ( "'CONSTRAINED IS 'FALSE' FOR " & "OBJECT OF " & "OUT MODE - 2" ); END IF; POUT := (2, ((1, 2), (3, 4))); END; END Q; END T; GENERIC PIN1, PIN2 : IN SQUARE; PINOUT : IN OUT SQUARE; PACKAGE R IS END R; PACKAGE BODY R IS BEGIN IF PIN1'CONSTRAINED THEN NULL; ELSE FAILED ( "'CONSTRAINED IS 'FALSE' FOR OBJECT " & "OF IN MODE - 5" ); END IF; IF PIN2'CONSTRAINED THEN NULL; ELSE FAILED ( "'CONSTRAINED IS 'FALSE' FOR OBJECT " & "OF IN MODE - 6" ); END IF; IF PINOUT'CONSTRAINED THEN NULL; ELSE FAILED ( "'CONSTRAINED IS 'FALSE' FOR " & "OBJECT OF IN OUT MODE - 3" ); END IF; END R; PACKAGE S IS NEW R (S1, SC, S2); BEGIN P (S1, SC, S2, S3); T.Q (S1, SC, S2, S3); END; RESULT;END C37403A;
⌨️ 快捷键说明
复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?