3 -- Grant of Unlimited Rights
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
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.
26 -- CHECK THAT EXPONENTIATION OF A LONG_INTEGER TO AN INTEGER VALUE
27 -- IS CORRECTLY EVALUATED.
29 -- APPLICABILITY CRITERIA:
30 -- THIS TEST IS APPLICABLE TO THOSE IMPLEMENTATIONS WHICH SUPPORT
33 -- IF "LONG_INTEGER" IS NOT SUPPORTED, THEN THE DECLARATION OF
34 -- "CHECK_LONG" MUST BE REJECTED.
37 -- HTG 09/23/86 CREATED ORIGINAL TEST.
38 -- DHH 01/13/88 ADDED APPLICABILITY CRITERIA AND STANDARD HEADER.
40 WITH REPORT; USE REPORT;
44 CHECK_LONG : LONG_INTEGER; -- N/A => ERROR.
46 I1,INT : LONG_INTEGER;
48 FUNCTION IDENT (X : LONG_INTEGER) RETURN LONG_INTEGER IS
50 RETURN LONG_INTEGER (IDENT_INT (INTEGER (X)));
56 TEST ("C45611C", "CHECK THAT EXPONENTIATION OF A " &
57 "LONG_INTEGER VALUE IS CORRECTLY " &
60 I1 := IDENT(0) ** IDENT_INT(0);
62 IF IDENT(I1) /= IDENT(1) THEN
63 FAILED( "INCORRECT RESULT FOR '0**0'" );
66 INT := "**" (IDENT(0),IDENT_INT(1));
68 IF IDENT(INT) /= IDENT(0) THEN
69 FAILED( "INCORRECT RESULT FOR '0**1'" );
72 I1 := IDENT(6) ** IDENT_INT(0);
74 IF IDENT(I1) /= IDENT(1) THEN
75 FAILED( "INCORRECT RESULT FOR '6**0'" );
78 INT := IDENT(156) ** IDENT_INT(1);
80 IF IDENT(INT) /= IDENT(156) THEN
81 FAILED( "INCORRECT RESULT FOR '156**1'" );
84 I1 := IDENT(-3) ** IDENT_INT(0);
86 IF IDENT(I1) /= IDENT(1) THEN
87 FAILED( "INCORRECT RESULT FOR '(-3)**0'" );
90 INT := "**" (IDENT(-7),IDENT_INT(1));
92 IF IDENT(INT) /= IDENT(-7) THEN
93 FAILED( "INCORRECT RESULT FOR '(-7)**1'" );
96 I1 := "**" (IDENT(-1),IDENT_INT(2));
98 IF IDENT(I1) /= IDENT(1) THEN
99 FAILED( "INCORRECT RESULT FOR '(-1)**2'" );
103 INT := IDENT(-1) ** IDENT_INT(3);
105 IF IDENT(INT) /= IDENT(-1) THEN
106 FAILED( "INCORRECT RESULT FOR '(-1)**3'" );
109 INT := "**" (IDENT(0),IDENT_INT(2));
111 IF IDENT(INT) /= IDENT(0) THEN
112 FAILED( "INCORRECT RESULT FOR '0**2'" );
115 INT := IDENT(0) ** IDENT_INT(10);
117 IF IDENT(INT) /= IDENT(0) THEN
118 FAILED( "INCORRECT RESULT FOR '0**10'" );
121 INT := "**" (IDENT(6),IDENT_INT(2));
123 IF IDENT(INT) /= IDENT(36) THEN
124 FAILED( "INCORRECT RESULT FOR '6**2'" );
127 INT := "**" (IDENT(2),IDENT_INT(2));
129 IF IDENT(INT) /= IDENT(4) THEN
130 FAILED( "INCORRECT RESULT FOR '2**2'" );
133 I1 := "**" (IDENT(1),IDENT_INT(10));
135 IF IDENT(I1) /= IDENT(1) THEN
136 FAILED( "INCORRECT RESULT FOR '1**10'" );