| -- C35503E.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. |
| --* |
| -- OBJECTIVE: |
| -- CHECK THAT 'IMAGE' AND 'VALUE' YIELD THE CORRECT RESULTS WHEN |
| -- THE PREFIX IS A GENERIC FORMAL DISCRETE TYPE WHOSE ACTUAL |
| -- PARAMETER IS AN INTEGER TYPE. |
| -- SUBTESTS ARE : |
| -- PART (A). TESTS FOR 'IMAGE'. |
| -- PART (B). TESTS FOR 'VALUE'. |
| |
| -- HISTORY: |
| -- RJW 03/17/86 CREATED ORIGINAL TEST. |
| -- DHH 10/19/87 SHORTENED LINES CONTAINING MORE THAN 72 CHARACTERS. |
| |
| WITH REPORT; USE REPORT; |
| |
| PROCEDURE C35503E IS |
| |
| BEGIN |
| TEST ("C35503E", "CHECK THAT 'IMAGE' AND 'VALUE' YIELD THE " & |
| "CORRECT RESULTS WHEN THE PREFIX IS A " & |
| "GENERIC FORMAL DISCRETE TYPE WHOSE ACTUAL " & |
| "PARAMETER IS AN INTEGER TYPE" ); |
| -- PART (A). |
| |
| DECLARE |
| TYPE NEWINT IS NEW INTEGER RANGE -2000 .. 2000; |
| |
| GENERIC |
| TYPE INT IS (<>); |
| PROCEDURE P (I1 : INT; STR : STRING ); |
| |
| PROCEDURE P (I1 : INT; STR : STRING) IS |
| SUBTYPE SUBINT IS INT |
| RANGE INT'VAL (IDENT_INT(-1000)) .. |
| INT'VAL (IDENT_INT(1000)); |
| BEGIN |
| |
| IF INT'IMAGE (I1) /= STR THEN |
| FAILED ( "INCORRECT INT'IMAGE OF " & STR ); |
| END IF; |
| IF INT'IMAGE (I1)'FIRST /= 1 THEN |
| FAILED ( "INCORRECT LOWER BOUND FOR INT'IMAGE OF " & |
| STR ); |
| END IF; |
| |
| IF SUBINT'IMAGE (I1) /= STR THEN |
| FAILED ( "INCORRECT SUBINT'IMAGE OF " & STR ); |
| END IF; |
| IF SUBINT'IMAGE (I1)'FIRST /= 1 THEN |
| FAILED ( "INCORRECT LOWER BOUND FOR SUBINT'IMAGE " & |
| "OF " & STR ); |
| END IF; |
| |
| END P; |
| |
| PROCEDURE PROC1 IS NEW P (INTEGER); |
| PROCEDURE PROC2 IS NEW P (NEWINT); |
| |
| BEGIN |
| PROC1 (-500, "-500"); |
| PROC2 (0, " 0"); |
| PROC2 (99," 99"); |
| END; |
| |
| ----------------------------------------------------------------------- |
| |
| -- PART (B). |
| |
| DECLARE |
| TYPE NEWINT IS NEW INTEGER; |
| |
| GENERIC |
| TYPE INT IS (<>); |
| PROCEDURE P (STR : STRING; I1 : INT ); |
| |
| PROCEDURE P (STR : STRING; I1 : INT) IS |
| SUBTYPE SUBINT IS INT |
| RANGE INT'VAL (IDENT_INT(0)) .. |
| INT'VAL (IDENT_INT(10)); |
| |
| BEGIN |
| BEGIN |
| IF INT'VALUE (STR) /= I1 THEN |
| FAILED ( "INCORRECT INT'VALUE OF """ & |
| STR & """"); |
| END IF; |
| EXCEPTION |
| WHEN OTHERS => |
| FAILED ( "EXCEPTION RAISED INT'VALUE OF """ & |
| STR & """"); |
| END; |
| BEGIN |
| IF SUBINT'VALUE (STR) /= I1 THEN |
| FAILED ( "INCORRECT SUBINT'VALUE OF """ & |
| STR & """"); |
| END IF; |
| EXCEPTION |
| WHEN OTHERS => |
| FAILED ( "EXCEPTION RAISED SUBINT'VALUE " & |
| "OF """ & STR & """"); |
| END; |
| END P; |
| |
| PROCEDURE PROC1 IS NEW P (INTEGER); |
| PROCEDURE PROC2 IS NEW P (NEWINT); |
| |
| BEGIN |
| PROC1 ("-500" , -500); |
| PROC2 (" -001E2 " , -100); |
| PROC1 ("3_45" , 345); |
| PROC2 ("-2#1111_1111#" , -255); |
| PROC1 ("16#FF#" , 255); |
| PROC2 ("-016#0FF#" , -255); |
| PROC1 ("2#1110_0000# " , 224); |
| PROC2 ("-16#E#E1" , -224); |
| |
| END; |
| |
| DECLARE |
| TYPE NEWINT IS NEW INTEGER; |
| |
| GENERIC |
| TYPE INT IS (<>); |
| PROCEDURE P (STR1 : STRING; I1 : INT; STR2 : STRING); |
| |
| PROCEDURE P (STR1 : STRING; I1 : INT; STR2 : STRING) IS |
| SUBTYPE SUBINT IS INT |
| RANGE INT'VAL (IDENT_INT(0)) .. |
| INT'VAL (IDENT_INT(10)); |
| |
| BEGIN |
| BEGIN |
| IF INT'VALUE (STR1) = I1 THEN |
| FAILED ( "NO EXCEPTION RAISED - INT'VALUE " & |
| "WITH " & STR2 & " - EQUAL"); |
| ELSE |
| FAILED ( "NO EXCEPTION RAISED " & |
| "- INT'VALUE WITH " & |
| STR2 & " - NOT EQUAL" ); |
| END IF; |
| EXCEPTION |
| WHEN CONSTRAINT_ERROR => |
| NULL; |
| WHEN OTHERS => |
| FAILED ( "WRONG EXCEPTION RAISED - " & |
| "INT'VALUE WITH " & STR2 ); |
| END; |
| BEGIN |
| IF SUBINT'VALUE (STR1) = I1 THEN |
| FAILED ( "NO EXCEPTION RAISED - " & |
| "SUBINT'VALUE WITH " & STR2 |
| & " - EQUAL" ); |
| ELSE |
| FAILED ( "NO EXCEPTION RAISED - " & |
| "SUBINT'VALUE WITH " & |
| STR2 & " - NOT EQUAL" ); |
| END IF; |
| EXCEPTION |
| WHEN CONSTRAINT_ERROR => |
| NULL; |
| WHEN OTHERS => |
| FAILED ( "WRONG EXCEPTION RAISED - " & |
| "SUBINT'VALUE WITH " & STR2 ); |
| END; |
| END P; |
| |
| PROCEDURE PROC1 IS NEW P (INTEGER); |
| PROCEDURE PROC2 IS NEW P (NEWINT); |
| |
| BEGIN |
| PROC1 ("1.0" , 1, "DECIMAL POINT"); |
| PROC1 (ASCII.HT & "244", 244, "LEADING 'HT'" ); |
| PROC2 ("244" & ASCII.HT, 244, "TRAILING 'HT'" ); |
| PROC1 ("2__44" , 244, "CONSECUTIVE '_'" ); |
| PROC2 ("_244" , 244, "LEADING '_'" ); |
| PROC1 ("244_" , 244, "TRAILING '_'" ); |
| PROC2 ("244_E1" , 2440, "'_' BEFORE 'E'" ); |
| PROC1 ("244E_1" , 2440, "'_' FOLLOWING 'E'" ); |
| PROC2 ("244_e1" , 2440, "'_' BEFORE 'e'" ); |
| PROC1 ("16#_FF#" , 255, "'_' IN BASED LITERAL" ); |
| PROC2 ("1E-0" , 0, "NEGATIVE EXPONENT" ); |
| PROC1 ("244." , 244, "TRAILING '.'" ); |
| PROC2 ("8#811#" , 0, "DIGITS OUTSIDE OF RANGE" ); |
| PROC1 ("1#000#" , 0, "BASE LESS THAN 2" ); |
| PROC2 ("17#0#" , 0, "BASE GREATER THAN 16" ); |
| END; |
| |
| RESULT; |
| END C35503E; |