1-- C41107A.ADA 2 3-- Grant of Unlimited Rights 4-- 5-- Under contracts F33600-87-D-0337, F33600-84-D-0280, MDA903-79-C-0687, 6-- F08630-91-C-0015, and DCA100-97-D-0025, the U.S. Government obtained 7-- unlimited rights in the software and documentation contained herein. 8-- Unlimited rights are defined in DFAR 252.227-7013(a)(19). By making 9-- this public release, the Government intends to confer upon all 10-- recipients unlimited rights equal to those held by the Government. 11-- These rights include rights to use, duplicate, release or disclose the 12-- released technical data and computer software in whole or in part, in 13-- any manner and for any purpose whatsoever, and to have or permit others 14-- to do so. 15-- 16-- DISCLAIMER 17-- 18-- ALL MATERIALS OR INFORMATION HEREIN RELEASED, MADE AVAILABLE OR 19-- DISCLOSED ARE AS IS. THE GOVERNMENT MAKES NO EXPRESS OR IMPLIED 20-- WARRANTY AS TO ANY MATTER WHATSOEVER, INCLUDING THE CONDITIONS OF THE 21-- SOFTWARE, DOCUMENTATION OR OTHER INFORMATION RELEASED, MADE AVAILABLE 22-- OR DISCLOSED, OR THE OWNERSHIP, MERCHANTABILITY, OR FITNESS FOR A 23-- PARTICULAR PURPOSE OF SAID MATERIAL. 24--* 25-- CHECK THAT FOR AN ARRAY HAVING BOTH POSITIVE AND NEGATIVE 26-- INDEX VALUES, THE PROPER COMPONENT IS SELECTED - A. 27-- CHECK THAT FOR AN ARRAY INDEXED WITH AN ENUMERATION TYPE, 28-- APPROPRIATE COMPONENTS CAN BE SELECTED - B. 29-- CHECK THAT SUBSCRIPT EXPRESSIONS CAN BE OF COMPLEXITY GREATER 30-- THAN VARIABLE + - CONSTANT - C. 31-- CHECK THAT MULTIPLY DIMENSIONED ARRAYS ARE PROPERLY INDEXED - D. 32 33-- WKB 7/29/81 34-- JBG 8/21/83 35 36WITH REPORT; 37USE REPORT; 38PROCEDURE C41107A IS 39 40 TYPE T1 IS ARRAY (INTEGER RANGE -2..2) OF INTEGER; 41 A : T1 := (1,2,3,4,5); 42 43 TYPE COLOR IS (RED,ORANGE,YELLOW,GREEN,BLUE); 44 TYPE T2 IS ARRAY (COLOR RANGE RED..BLUE) OF INTEGER; 45 B : T2 := (5,4,3,2,1); 46 47 C : STRING (1..7) := "ABCDEFG"; 48 49 TYPE T4 IS ARRAY (1..4,1..3) OF INTEGER; 50 D : T4 := (1 => (1,2,3), 2 => (4,5,6), 3 => (7,8,9), 51 4 => (0,-1,-2)); 52 53 V1 : INTEGER := IDENT_INT (1); 54 V2 : INTEGER := IDENT_INT (2); 55 V3 : INTEGER := IDENT_INT (3); 56 57 PROCEDURE P1 (X : IN INTEGER; Y : IN OUT INTEGER; 58 Z : OUT INTEGER; W : STRING) IS 59 BEGIN 60 IF X /= 1 THEN 61 FAILED ("WRONG VALUE FOR IN PARAMETER - " & W); 62 END IF; 63 IF Y /= 4 THEN 64 FAILED ("WRONG VALUE FOR IN OUT PARAMETER - " & W); 65 END IF; 66 Y := 11; 67 Z := 12; 68 END P1; 69 70 PROCEDURE P2 (X : IN CHARACTER; Y : IN OUT CHARACTER; 71 Z : OUT CHARACTER) IS 72 BEGIN 73 IF X /= 'D' THEN 74 FAILED ("WRONG VALUE FOR IN PARAMETER - C"); 75 END IF; 76 IF Y /= 'F' THEN 77 FAILED ("WRONG VALUE FOR IN OUT PARAMETER - C"); 78 END IF; 79 Y := 'Y'; 80 Z := 'Z'; 81 END P2; 82 83BEGIN 84 TEST ("C41107A", "CHECK THAT THE PROPER COMPONENT IS SELECTED " & 85 "FOR ARRAYS WITH POS AND NEG INDICES, " & 86 "ENUMERATION INDICES, COMPLEX SUBSCRIPT " & 87 "EXPRESSIONS, AND MULTIPLE DIMENSIONS"); 88 89 IF A(IDENT_INT(1)) /= 4 THEN 90 FAILED ("WRONG VALUE FOR EXPRESSION - A"); 91 END IF; 92 A(IDENT_INT(-2)) := 10; 93 IF A /= (10,2,3,4,5) THEN 94 FAILED ("WRONG TARGET FOR ASSIGNMENT - A"); 95 END IF; 96 A := (2,1,0,3,4); 97 P1 (A(-1), A(2), A(-2), "A"); 98 IF A /= (12,1,0,3,11) THEN 99 FAILED ("WRONG TARGET FOR (IN) OUT PARAMETER - A"); 100 END IF; 101 102 IF B(GREEN) /= 2 THEN 103 FAILED ("WRONG VALUE FOR EXPRESSION - B"); 104 END IF; 105 B(YELLOW) := 10; 106 IF B /= (5,4,10,2,1) THEN 107 FAILED ("WRONG TARGET FOR ASSIGNMENT - B"); 108 END IF; 109 B := (1,4,2,3,5); 110 P1 (B(RED), B(ORANGE), B(BLUE), "B"); 111 IF B /= (1,11,2,3,12) THEN 112 FAILED ("WRONG TARGET FOR (IN) OUT PARAMETER - B"); 113 END IF; 114 115 IF C(3..6)(3**2 / 3 * (2-1) - 6 / 3 + 2) /= 'C' THEN 116 FAILED ("WRONG VALUE FOR EXPRESSION - C"); 117 END IF; 118 C(3..6)(V3**2 / V1 * (V3-V2) + IDENT_INT(4) - V3 * V2 - V1) := 'W'; 119 IF C /= "ABCDEWG" THEN 120 FAILED ("WRONG TARGET FOR ASSIGNMENT - C"); 121 END IF; 122 C := "ABCDEFG"; 123 P2 (C(3..6)(V3+V1), C(3..6)(V3*V2), C(3..6)((V1+V2)*V1)); 124 IF C /= "ABZDEYG" THEN 125 FAILED ("WRONG TARGET FOR (IN) OUT PARAMETER - C"); 126 END IF; 127 128 IF D(IDENT_INT(1),IDENT_INT(3)) /= 3 THEN 129 FAILED ("WRONG VALUE FOR EXPRESSION - D"); 130 END IF; 131 D(IDENT_INT(4),IDENT_INT(2)) := 10; 132 IF D /= ((1,2,3),(4,5,6),(7,8,9),(0,10,-2)) THEN 133 FAILED ("WRONG TARGET FOR ASSIGNMENT - D"); 134 END IF; 135 D := (1 => (0,2,3), 2 => (4,5,6), 3 => (7,8,9), 4 => (1,-1,-2)); 136 P1 (D(4,1), D(2,1), D(3,2), "D"); 137 IF D /= ((0,2,3),(11,5,6),(7,12,9),(1,-1,-2)) THEN 138 FAILED ("WRONG TARGET FOR (IN) OUT PARAMETER - D"); 139 END IF; 140 141 RESULT; 142END C41107A; 143