#include "perms.h"

                                                                //      1  %begin
#line 1 "regression-compile-tmp/array2d.imp"
int main(int argc, char **argv) {
  __label__ _imp_endofblock;
  _imp_initialise(argc, argv);
                                                                //      2  
                                                                //      3    %routine printarray(%integerarray(2)%name A, %integer a0low, a0high, a1low, a1high)
_imp_current_line = 3; _imp_current_file = "regression-compile-tmp/array2d.imp";
#line 3 "regression-compile-tmp/array2d.imp"
void PRINTARRAY( int /*arrayname*/*A, int A0LOW, int A0HIGH, int A1LOW, int A1HIGH )
#line 3 "regression-compile-tmp/array2d.imp"
{
  __label__ _imp_endofblock;
                                                                //      4      %integer A0, A1
_imp_current_line = 4; _imp_current_file = "regression-compile-tmp/array2d.imp";
#line 4 "regression-compile-tmp/array2d.imp"
int A0;
#line 4 "regression-compile-tmp/array2d.imp"
int A1;
                                                                //      5      ! Imp needs some perm code to determine upper and lower bounds of arrays
                                                                //      6      %for A0 = a0low, 1, a0high %cycle
_imp_current_line = 6; _imp_current_file = "regression-compile-tmp/array2d.imp";
#line 6 "regression-compile-tmp/array2d.imp"
{static int _initial, _increment, _final, _control;
_initial = A0LOW; _increment = 1; _final = A0HIGH; A0 = _control = _initial;
if (((_final-_initial) % _increment) != 0) _imp_signal(5,1,0,"Illegal cycle A0 = A0LOW, 1, A0HIGH");
A0 -= _increment; _control -= _increment;
L_0002:;
if (A0 == _final) goto L_0003;
A0 += _increment; _control += _increment;
if (A0 != _control) _imp_signal(4,2,0,"Corrupt control variable A0"); /* FOR loop control variable corrupted */
}
                                                                //      7        %for A1 = a1low, 1, a1high %cycle
_imp_current_line = 7; _imp_current_file = "regression-compile-tmp/array2d.imp";
#line 7 "regression-compile-tmp/array2d.imp"
{static int _initial, _increment, _final, _control;
_initial = A1LOW; _increment = 1; _final = A1HIGH; A1 = _control = _initial;
if (((_final-_initial) % _increment) != 0) _imp_signal(5,1,0,"Illegal cycle A1 = A1LOW, 1, A1HIGH");
A1 -= _increment; _control -= _increment;
L_0005:;
if (A1 == _final) goto L_0006;
A1 += _increment; _control += _increment;
if (A1 != _control) _imp_signal(4,2,0,"Corrupt control variable A1"); /* FOR loop control variable corrupted */
}
                                                                //      8          write(A(A0, A1), 3); print string(", ")
_imp_current_line = 8; _imp_current_file = "regression-compile-tmp/array2d.imp";
#line 8 "regression-compile-tmp/array2d.imp"
_imp_WRITE(A[A1], 3);
_imp_current_line = 8; _imp_current_file = "regression-compile-tmp/array2d.imp";
#line 8 "regression-compile-tmp/array2d.imp"
_imp_PRINTSTRING(_imp_str_literal(", "));
                                                                //      9        %repeat
_imp_current_line = 9; _imp_current_file = "regression-compile-tmp/array2d.imp";
#line 9 "regression-compile-tmp/array2d.imp"
goto L_0005;
#line 9 "regression-compile-tmp/array2d.imp"
L_0006:;
                                                                //     10        newline
_imp_current_line = 10; _imp_current_file = "regression-compile-tmp/array2d.imp";
#line 10 "regression-compile-tmp/array2d.imp"
_imp_NEWLINE();
                                                                //     11      %repeat
_imp_current_line = 11; _imp_current_file = "regression-compile-tmp/array2d.imp";
#line 11 "regression-compile-tmp/array2d.imp"
goto L_0002;
#line 11 "regression-compile-tmp/array2d.imp"
L_0003:;
                                                                //     12      newline
_imp_current_line = 12; _imp_current_file = "regression-compile-tmp/array2d.imp";
#line 12 "regression-compile-tmp/array2d.imp"
_imp_NEWLINE();
                                                                //     13    %end
_imp_current_line = 13; _imp_current_file = "regression-compile-tmp/array2d.imp";
#line 13 "regression-compile-tmp/array2d.imp"
return;
_imp_endofblock: ;
} // End of block PRINTARRAY at level 2
                                                                //     14  
                                                                //     15    %integername element
_imp_current_line = 15; _imp_current_file = "regression-compile-tmp/array2d.imp";
#line 15 "regression-compile-tmp/array2d.imp"
int /*name*/*ELEMENT;
                                                                //     16    %integer i
_imp_current_line = 16; _imp_current_file = "regression-compile-tmp/array2d.imp";
#line 16 "regression-compile-tmp/array2d.imp"
int I;
                                                                //     17  
                                                                //     18    ! imp77 doesn't allow initialised multi-dimensional arrays.  (Imp80 would!)
                                                                //     19    ! So I'll initialise these explicitly:
                                                                //     20    %integerarray fred(0:1, 0:2)       { simple case }
_imp_current_line = 20; _imp_current_file = "regression-compile-tmp/array2d.imp";
#line 20 "regression-compile-tmp/array2d.imp"
int FRED[2][3];
                                                                //     21    %integerarray jim(11:13, 100:103)  { non-zero lower bounds }
_imp_current_line = 21; _imp_current_file = "regression-compile-tmp/array2d.imp";
#line 21 "regression-compile-tmp/array2d.imp"
int JIM[3][4];
                                                                //     22    element == fred(0,0); element = i %and element == element++1 %for i = 0, 1, 5
_imp_current_line = 22; _imp_current_file = "regression-compile-tmp/array2d.imp";
#line 22 "regression-compile-tmp/array2d.imp"
ELEMENT = &FRED[0][0];
_imp_current_line = 22; _imp_current_file = "regression-compile-tmp/array2d.imp";
#line 22 "regression-compile-tmp/array2d.imp"
I = (-1);
if ((((5)-(0)) % (1)) != 0) _imp_signal(5,1,0,"Illegal cycle I = 0, 1, 5");
L_0008:;
if (I == 5) goto L_0009;
I += 1;
#line 22 "regression-compile-tmp/array2d.imp"
*ELEMENT = I;
#line 22 "regression-compile-tmp/array2d.imp"
ELEMENT = /*F_VOID*/((ELEMENT) + (1));
#line 22 "regression-compile-tmp/array2d.imp"
goto L_0008;
#line 22 "regression-compile-tmp/array2d.imp"
L_0009:;
                                                                //     23    element == jim(11,100); element = i %and element == element++1 %for i = 0, 1, 11
_imp_current_line = 23; _imp_current_file = "regression-compile-tmp/array2d.imp";
#line 23 "regression-compile-tmp/array2d.imp"
ELEMENT = &JIM[(-89)][89];
_imp_current_line = 23; _imp_current_file = "regression-compile-tmp/array2d.imp";
#line 23 "regression-compile-tmp/array2d.imp"
I = (-1);
if ((((11)-(0)) % (1)) != 0) _imp_signal(5,1,0,"Illegal cycle I = 0, 1, 11");
L_000b:;
if (I == 11) goto L_000c;
I += 1;
#line 23 "regression-compile-tmp/array2d.imp"
*ELEMENT = I;
#line 23 "regression-compile-tmp/array2d.imp"
ELEMENT = /*F_VOID*/((ELEMENT) + (1));
#line 23 "regression-compile-tmp/array2d.imp"
goto L_000b;
#line 23 "regression-compile-tmp/array2d.imp"
L_000c:;
                                                                //     24  
                                                                //     25    printarray(fred, 0,1, 0,2)
_imp_current_line = 25; _imp_current_file = "regression-compile-tmp/array2d.imp";
#line 25 "regression-compile-tmp/array2d.imp"
PRINTARRAY(&FRED[-(0)][-(0)], 0, 1, 0, 2);
                                                                //     26    printarray(jim, 11,13, 100,103)
_imp_current_line = 26; _imp_current_file = "regression-compile-tmp/array2d.imp";
#line 26 "regression-compile-tmp/array2d.imp"
PRINTARRAY(&JIM[-(100)][-(11)], 11, 13, 100, 103);
                                                                //     27    
                                                                //     28  %endofprogram
_imp_current_line = 28; _imp_current_file = "regression-compile-tmp/array2d.imp";
#line 28 "regression-compile-tmp/array2d.imp"
return 0;
_imp_endofblock: ;
} // End of block _imp_main at level 1
#line 28 "regression-compile-tmp/array2d.imp"
// End of file
