2003-12-26 Guilhem Lavaux <guilhem@kaffe.org>
[official-gcc.git] / gcc / testsuite / ada / acats / tests / c4 / c45611b.dep
blobfb63ef82e8026661bca3cad2d19f2e31528a20b7
1 --  C45611B.DEP
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.
16 --                                    DISCLAIMER
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 -- OBJECTIVE:
26 --     CHECK THAT EXPONENTIATION OF A SHORT_INTEGER TO AN INTEGER VALUE
27 --     IS CORRECTLY EVALUATED.
29 -- APPLICABILITY CRITERIA:
30 --     THIS TEST IS APPLICABLE TO THOSE IMPLEMENTATIONS WHICH SUPPORT
31 --     SHORT_INTEGER.
33 --     IF "SHORT_INTEGER" IS NOT SUPPORTED, THEN THE DECLARATION OF
34 --     "CHECK_SHORT" MUST BE REJECTED.
36 -- HISTORY:
37 --     HTG 09/23/86 CREATED ORIGINAL TEST.
38 --     DHH 01/13/88 ADDED APPLICABILITY CRITERIA AND STANDARD HEADER.
40 WITH REPORT; USE REPORT;
42 PROCEDURE C45611B IS
44     CHECK_SHORT : SHORT_INTEGER;                   -- N/A => ERROR.
46     I1,INT : SHORT_INTEGER;
48     FUNCTION IDENT (X : SHORT_INTEGER) RETURN SHORT_INTEGER IS
49     BEGIN
50          RETURN SHORT_INTEGER (IDENT_INT (INTEGER (X)));
51     END IDENT;
53     BEGIN
56          TEST ("C45611B", "CHECK THAT EXPONENTIATION OF A " &
57                           "SHORT_INTEGER VALUE IS CORRECTLY " &
58                           "EVALUATED");
60          I1 := IDENT(0) ** IDENT_INT(0);
62          IF IDENT(I1) /= IDENT(1) THEN
63               FAILED( "INCORRECT RESULT FOR '0**0'" );
64          END IF;
66          INT := "**" (IDENT(0),IDENT_INT(1));
68          IF IDENT(INT) /= IDENT(0) THEN
69               FAILED( "INCORRECT RESULT FOR '0**1'" );
70          END IF;
72          I1 := IDENT(6) ** IDENT_INT(0);
74          IF IDENT(I1) /= IDENT(1) THEN
75               FAILED( "INCORRECT RESULT FOR '6**0'" );
76          END IF;
78          INT := IDENT(15) ** IDENT_INT(1);
80          IF IDENT(INT) /= IDENT(15) THEN
81               FAILED( "INCORRECT RESULT FOR '15**1'" );
82          END IF;
84          I1 := IDENT(-3) ** IDENT_INT(0);
86          IF IDENT(I1) /= IDENT(1) THEN
87               FAILED( "INCORRECT RESULT FOR '(-3)**0'" );
88          END IF;
90          INT := "**" (IDENT(-7),IDENT_INT(1));
92          IF IDENT(INT) /= IDENT(-7) THEN
93               FAILED( "INCORRECT RESULT FOR '(-7)**1'" );
94          END IF;
96          I1 := "**" (IDENT(-1),IDENT_INT(2));
98          IF IDENT(I1) /= IDENT(1) THEN
99               FAILED( "INCORRECT RESULT FOR '(-1)**2'" );
100          END IF;
103          INT := IDENT(-1) ** IDENT_INT(3);
105          IF IDENT(INT) /= IDENT(-1) THEN
106               FAILED( "INCORRECT RESULT FOR '(-1)**3'" );
107          END IF;
109          INT := "**" (IDENT(0),IDENT_INT(2));
111          IF IDENT(INT) /= IDENT(0) THEN
112               FAILED( "INCORRECT RESULT FOR '0**2'" );
113          END IF;
115          INT := IDENT(0) ** IDENT_INT(10);
117          IF IDENT(INT) /= IDENT(0) THEN
118               FAILED( "INCORRECT RESULT FOR '0**10'" );
119          END IF;
121          INT := "**" (IDENT(6),IDENT_INT(2));
123          IF IDENT(INT) /= IDENT(36) THEN
124               FAILED( "INCORRECT RESULT FOR '6**2'" );
125          END IF;
127          INT := "**" (IDENT(2),IDENT_INT(2));
129          IF IDENT(INT) /= IDENT(4) THEN
130               FAILED( "INCORRECT RESULT FOR '2**2'" );
131          END IF;
133          I1 := "**" (IDENT(1),IDENT_INT(10));
135          IF IDENT(I1) /= IDENT(1) THEN
136               FAILED( "INCORRECT RESULT FOR '1**10'" );
137          END IF;
139          RESULT;
141     END C45611B;