summaryrefslogtreecommitdiff
path: root/gcc/testsuite/ada/acats/tests/c4/c45344a.ada
blob: b75f2a7ef0a7b7bdd823827b36b546bd6cb4a97b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
-- C45344A.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 CORRECT RESULT IS PRODUCED WHEN A FUNCTION RETURNS 
-- THE RESULT OF A CATENATION WHOSE BOUNDS ARE NOT DEFINED STATICALLY.

-- R.WILLIAMS 9/1/86

WITH REPORT; USE REPORT;
PROCEDURE C45344A IS

BEGIN
     TEST ( "C45344A", "CHECK THAT THE CORRECT RESULT IS PRODUCED " &
                       "WHEN A FUNCTION RETURNS THE RESULT OF A " &
                       "CATENATION WHOSE BOUNDS ARE NOT DEFINED " &
                       "STATICALLY" );

     DECLARE
          SUBTYPE INT IS INTEGER RANGE IDENT_INT (1) .. IDENT_INT (30);

          TYPE ARR IS ARRAY (INT RANGE <>) OF INTEGER;
          SUBTYPE CARR IS ARR (1 .. 9);
          C : CARR;
          
          AR1 : ARR (IDENT_INT (2) .. IDENT_INT (4)) :=
                    (IDENT_INT (2) .. IDENT_INT (4) => 1);

          AR2 : ARR (IDENT_INT (6) .. IDENT_INT (6)) :=
                    (IDENT_INT (6) .. IDENT_INT (6) => 2);

          AR3 : ARR (IDENT_INT (4) .. IDENT_INT (2));
     
          FUNCTION F (A, B : ARR; N : NATURAL) RETURN ARR IS
          BEGIN
               IF N = 0 THEN
                    RETURN A & B;
               ELSE
                    RETURN F (A & B, B, N - 1);
               END IF;
          END F;
     
          FUNCTION G (A : INTEGER; B : ARR; N : NATURAL) RETURN ARR IS
          BEGIN
               IF N = 0 THEN
                    RETURN A & B;
               ELSE
                    RETURN G (A, A & B, N - 1);
               END IF;
          END G;

          FUNCTION H (A : ARR; B : INTEGER; N : NATURAL) RETURN ARR IS
          BEGIN
               IF N = 0 THEN
                    RETURN A & B;
               ELSE
                    RETURN H (A & B, B, N - 1);
               END IF;
          END H;
     
          PROCEDURE CHECK (X, Y : ARR; F, L : INTEGER; STR : STRING) IS
               OK : BOOLEAN := TRUE;
          BEGIN
               IF X'FIRST /= F AND X'LAST /= L THEN
                    FAILED ( "INCORRECT RANGE FOR " & STR);
               ELSE
                    FOR I IN F .. L LOOP
                         IF X (I) /= Y (I) THEN
                              OK := FALSE;
                         END IF;
                    END LOOP;
     
                    IF NOT OK THEN
                         FAILED ( "INCORRECT VALUE FOR " & STR);
                    END IF;
               END IF;
          END CHECK;

     BEGIN
          C := (1 .. 4 => 1, 5 .. 9 => 2);
          CHECK (F (AR1, AR2, IDENT_INT (3)), C, 2, 8, "F - 1" );
          CHECK (F (AR3, AR2, IDENT_INT (3)), C, 6, 9, "F - 2" );
          CHECK (F (AR2, AR3, IDENT_INT (3)), C, 6, 6, "F - 3" );

          C := (1 ..4 => 5, 5 .. 9 => 1);
          CHECK (G (5, AR1, IDENT_INT (3)), C, 1, 7, "G - 1" );
          CHECK (G (5, AR3, IDENT_INT (3)), C, 1, 4, "G - 2" );

          CHECK (H (AR3, 5, IDENT_INT (3)), C, 1, 4, "H - 1" );

          C := (1 ..4 => 1, 5 .. 9 => 5);
          CHECK (H (AR1, 5, IDENT_INT (3)), C, 2, 8, "H - 2" );
     END;

     RESULT;
END C45344A;