c41301a.ada

来自「用于进行gcc测试」· ADA 代码 · 共 217 行

ADA
217
字号
-- C41301A.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 THE NOTATION L.R MAY BE USED TO DENOTE A RECORD COMPONENT,--   WHERE R IS THE IDENTIFIER OF SUCH COMPONENT, AND L MAY BE ANY OF--   THE FOLLOWING:--        AN IDENTIFIER DENOTING A RECORD OBJECT - X2;--        AN IDENTIFIER DENOTING AN ACCESS OBJECT WHOSE VALUE DESIGNATES--           A RECORD OBJECT - X3;--        A FUNCTION CALL DELIVERING A RECORD VALUE - F1;--        A FUNCTION CALL DELIVERING AN ACCESS VALUE DESIGNATING A--           RECORD OBJECT - F2;--        AN INDEXED COMPONENT - X4;--        AN IDENTIFIER PREFIXED BY THE NAME OF THE INNERMOST UNIT--           ENCLOSING THE IDENTIFIER'S DECLARATION - C41301A.X1;--        A SELECTED COMPONENT DENOTING A RECORD (WHICH IS A COMPONENT--           OF ANOTHER RECORD) - X5.-- WKB 8/13/81-- JRK 8/17/81-- SPS 10/26/82WITH REPORT;USE REPORT;PROCEDURE C41301A IS     TYPE T1 IS          RECORD               A : INTEGER;               B : BOOLEAN;               C : BOOLEAN;          END RECORD;     X1 : T1 := (A=>1, B=>TRUE, C=>FALSE);BEGIN     TEST ("C41301A", "CHECK THAT THE NOTATION L.R MAY BE USED TO " &                      "DENOTE A RECORD COMPONENT, WHERE R IS THE " &                      "IDENTIFIER AND L MAY BE OF CERTAIN FORMS");     DECLARE          TYPE T2 (DISC : INTEGER := 0) IS               RECORD                    D : BOOLEAN;                    E : INTEGER;                    F : BOOLEAN;                    CASE DISC IS                         WHEN 1 =>                              G : BOOLEAN;                         WHEN 2 =>                              H : INTEGER;                         WHEN OTHERS =>                              NULL;                    END CASE;               END RECORD;          X2 : T2(2) := (DISC=>2, D=>TRUE, E=>3, F=>FALSE, H=>1);          TYPE T3 IS ACCESS T1;          X3 : T3 := NEW T1' (A=>1, B=>TRUE, C=>FALSE);          TYPE T4 IS ARRAY (1..3) OF T1;          X4 : T4 := (1 => (1, TRUE, FALSE),                      2 => (2, FALSE, TRUE),                      3 => (3, TRUE, FALSE));          TYPE T5 IS               RECORD                    I : INTEGER;                    J : T1;               END RECORD;          X5 : T5 := (I => 5, J => (6, FALSE, TRUE));          FUNCTION F1 RETURN T2 IS          BEGIN               RETURN (DISC=>1, D=>FALSE, E=>3, F=>TRUE, G=>FALSE);          END F1;          FUNCTION F2 RETURN T3 IS          BEGIN               RETURN X3;          END F2;          PROCEDURE P1 (X : IN BOOLEAN; Y : IN OUT INTEGER;                        Z : OUT BOOLEAN; W : STRING) IS          BEGIN               IF X /= TRUE THEN                    FAILED ("WRONG VALUE FOR IN PARAMETER - " & W);               END IF;               IF Y /= 1 THEN                    FAILED ("WRONG VALUE FOR IN OUT PARAMETER - " & W);               END IF;               Y := 10;               Z := TRUE;          END P1;          PROCEDURE P2 (X : IN INTEGER) IS          BEGIN               IF X /= 1 THEN                    FAILED ("WRONG VALUE FOR IN PARAMETER - F1");               END IF;          END P2;     BEGIN          IF X2.E /= 3 THEN               FAILED ("WRONG VALUE FOR EXPRESSION - X2");          END IF;          X2.E := 5;          IF X2 /= (2, TRUE, 5, FALSE, 1) THEN               FAILED ("WRONG TARGET FOR ASSIGNMENT - X2");          END IF;          X2 := (DISC=>2, D=>TRUE, E=>3, F=>FALSE, H=>1);          P1 (X2.D, X2.H, X2.F, "X2");          IF X2 /= (2, TRUE, 3, TRUE, 10) THEN               FAILED ("WRONG TARGET FOR (IN) OUT PARAMETER - X2");          END IF;          IF X3.C /= FALSE THEN               FAILED ("WRONG VALUE FOR EXPRESSION - X3");          END IF;          X3.A := 5;          IF X3.ALL /= (5, TRUE, FALSE) THEN               FAILED ("WRONG TARGET FOR ASSIGNMENT - X3");          END IF;          X3 := NEW T1 '(A=>1, B=>TRUE, C=>FALSE);          P1 (X3.B, X3.A, X3.C, "X3");          IF X3.ALL /= (10, TRUE, TRUE) THEN               FAILED ("WRONG TARGET FOR (IN) OUT PARAMETER - X3");          END IF;          IF F1.G /= FALSE THEN               FAILED ("WRONG VALUE FOR EXPRESSION - F1");          END IF;          P2 (F1.DISC);          X3 := NEW T1' (A=>3, B=>FALSE, C=>TRUE);          IF F2.B /= FALSE THEN               FAILED ("WRONG VALUE FOR EXPRESSION - F2");          END IF;          F2.A := 4;          IF X3.ALL /= (4, FALSE, TRUE) THEN               FAILED ("WRONG TARGET FOR ASSIGNMENT - F2");          END IF;          X3 := NEW T1' (A=>1, B=>FALSE, C=>TRUE);          P1 (F2.C, F2.A, F2.B, "F2");          IF X3.ALL /= (10, TRUE, TRUE) THEN               FAILED ("WRONG TARGET FOR (IN) OUT PARAMETER - F2");          END IF;          IF X4(2).C /= TRUE THEN               FAILED ("WRONG VALUE FOR EXPRESSION - X4");          END IF;          X4(3).A := 4;          IF X4 /= ((1,TRUE,FALSE), (2,FALSE,TRUE), (4,TRUE,FALSE)) THEN               FAILED ("WRONG TARGET FOR ASSIGNMENT - X4");          END IF;          X4 := (1 => (2,TRUE,FALSE), 2 => (1,FALSE,TRUE),                 3 => (3,TRUE,FALSE));          P1 (X4(3).B, X4(2).A, X4(1).C, "X4");          IF X4 /= ((2,TRUE,TRUE), (10,FALSE,TRUE), (3,TRUE,FALSE)) THEN               FAILED ("WRONG TARGET FOR (IN) OUT PARAMETER - X4");          END IF;          X1 := (A=>1, B=>FALSE, C=>TRUE);          IF C41301A.X1.C /= TRUE THEN               FAILED ("WRONG VALUE FOR EXPRESSION - C41301A.X1");          END IF;          C41301A.X1.B := TRUE;          IF X1 /= (1, TRUE, TRUE) THEN               FAILED ("WRONG TARGET FOR ASSIGNMENT - C41301A.X1");          END IF;          X1 := (A=>1, B=>FALSE, C=>TRUE);          P1 (C41301A.X1.C, C41301A.X1.A, C41301A.X1.B, "C41301A.X1");          IF X1 /= (10, TRUE, TRUE) THEN               FAILED ("WRONG TARGET FOR (IN) OUT PARAMETER - " &                       "C41301A.X1");          END IF;          IF X5.J.C /= TRUE THEN               FAILED ("WRONG VALUE FOR EXPRESSION - X5");          END IF;          X5.J.C := FALSE;          IF X5 /= (5, (6, FALSE, FALSE)) THEN               FAILED ("WRONG TARGET FOR ASSIGNMENT - X5");          END IF;          X5 := (I => 5, J => (A=>1, B=>TRUE, C=>FALSE));          P1 (X5.J.B, X5.J.A, X5.J.C, "X5");          IF X5 /= (5, (10, TRUE, TRUE)) THEN               FAILED ("WRONG TARGET FOR (IN) OUT PARAMETER - X5");          END IF;     END;     RESULT;END C41301A;

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?