diff options
Diffstat (limited to 'test/rlhc.d/case/cond1_java.java-J-T1--goto-backend.exp')
-rw-r--r-- | test/rlhc.d/case/cond1_java.java-J-T1--goto-backend.exp | 466 |
1 files changed, 466 insertions, 0 deletions
diff --git a/test/rlhc.d/case/cond1_java.java-J-T1--goto-backend.exp b/test/rlhc.d/case/cond1_java.java-J-T1--goto-backend.exp new file mode 100644 index 00000000..3b4fe028 --- /dev/null +++ b/test/rlhc.d/case/cond1_java.java-J-T1--goto-backend.exp @@ -0,0 +1,466 @@ +class cond1_java +{ + int i ; + int j ; + int k ; + + + + + + private static byte _foo_key_offsets [] = { 0, 0, 2, 4, 6, 8, 10, 12, 13, 14, 15, 16, 17, 18, 19, 20, 0 , }; + private static char _foo_trans_keys [] = { 48, 49, 48, 49, 48, 49, 97, 98, 97, 98, 97, 98, 99, 10, 99, 99, 99, 99, 99, 99, 0, }; + private static byte _foo_single_lengths [] = { 0, 0, 0, 0, 2, 2, 2, 1, 1, 1, 1, 1, 1, 1, 1, 0, 0 , }; + private static byte _foo_range_lengths [] = { 0, 1, 1, 1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 , }; + private static byte _foo_index_offsets [] = { 0, 0, 2, 4, 6, 9, 12, 15, 17, 19, 21, 23, 25, 27, 29, 31, 0 , }; + private static byte _foo_trans_cond_spaces [] = { -1, -1, -1, -1, -1, -1, -1, 1, -1, -1, 5, -1, -1, 4, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 0 , }; + private static byte _foo_trans_offsets [] = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 17, 18, 19, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 0 , }; + private static byte _foo_trans_lengths [] = { 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 7, 1, 1, 3, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0 , }; + private static byte _foo_cond_keys [] = { 0, 0, 0, 0, 0, 0, 0, 1, 0, 0, 1, 2, 3, 4, 5, 6, 7, 0, 0, 1, 2, 3, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 , }; + private static byte _foo_cond_targs [] = { 2, 0, 3, 0, 4, 0, 5, 7, 0, 6, 11, 7, 12, 9, 13, 10, 14, 0, 6, 7, 9, 10, 0, 8, 0, 15, 0, 8, 0, 8, 0, 8, 0, 8, 0, 8, 0, 8, 0, 0, 0 , }; + private static byte _foo_cond_actions [] = { 1, 0, 2, 0, 3, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 4, 0, 5, 0, 6, 0, 7, 0, 8, 0, 9, 0, 10, 0, 11, 0, 0, 0 , }; + private static byte _foo_nfa_targs [] = { 0, 0 , }; + private static byte _foo_nfa_offsets [] = { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 , }; + private static byte _foo_nfa_push_actions [] = { 0, 0 , }; + private static byte _foo_nfa_pop_trans [] = { 0, 0 , }; + private static int foo_start = 1; + private static int foo_first_final = 15; + private static int foo_error = 0; + private static int foo_en_main = 1; + int cs; + + void init() + { + { + cs = (int)foo_start; + + } + } + + void exec( char data[], int len ) + { + char buffer [] = new char[1024]; + int blen = 0; + int p = 0; + int pe = len; + + String _s; + { + int _klen; + int _keys; + int _ckeys; + int _cpc; + int _trans = 0; + int _cond = 0; + int _nbreak; + int _goto_targ = 0; + _goto: while ( true ) { + switch ( _goto_targ ) { + case 0: + if ( p == pe ) + { + _goto_targ = 5; + if (true) + continue _goto; + } + + if ( cs == 0 ) + { + _goto_targ = 6; + if (true) + continue _goto; + } + + case 1: + _keys = _foo_key_offsets[cs] ; + _trans = (int )_foo_index_offsets[cs]; + _klen = (int)_foo_single_lengths[cs]; + if ( _klen > 0 ) + { + int _lower; + int _mid; + int _upper; + _lower = _keys; + _upper = _keys + _klen - 1; + while ( true ) + { + if ( _upper < _lower ) + break; + + + _mid = _lower + ((_upper-_lower) >> 1); + if ( ( data[p ]) < _foo_trans_keys[_mid ] ) + _upper = _mid - 1; + + else if ( ( data[p ]) > _foo_trans_keys[_mid ] ) + _lower = _mid + 1; + + else + { + _trans += (int )(_mid - _keys); + { + _goto_targ = 2; + if (true) + continue _goto; + } + + } + + + } + + _keys += _klen; + _trans += (int )_klen; + + } + + _klen = (int)_foo_range_lengths[cs]; + if ( _klen > 0 ) + { + int _lower; + int _mid; + int _upper; + _lower = _keys; + _upper = _keys + (_klen<<1) - 2; + while ( true ) + { + if ( _upper < _lower ) + break; + + + _mid = _lower + (((_upper-_lower) >> 1) & ~1); + if ( ( data[p ]) < _foo_trans_keys[_mid ] ) + _upper = _mid - 2; + + else if ( ( data[p ]) > _foo_trans_keys[_mid + 1 ] ) + _lower = _mid + 2; + + else + { + _trans += (int )((_mid - _keys)>>1); + { + _goto_targ = 2; + if (true) + continue _goto; + } + + } + + + } + + _trans += (int )_klen; + + } + + + case 2: + _ckeys = _foo_trans_offsets[_trans] ; + _klen = (int)_foo_trans_lengths[_trans]; + _cond = (int )_foo_trans_offsets[_trans]; + _cpc = 0; + switch ( _foo_trans_cond_spaces[_trans] ) { + case 0 : + if ( (i != 0) ) + _cpc += 1; + + + break; + case 1 : + if ( (j != 0) ) + _cpc += 1; + + + break; + case 2 : + if ( (k != 0) ) + _cpc += 1; + + + break; + case 3 : + if ( (i != 0) ) + _cpc += 1; + + if ( (j != 0) ) + _cpc += 2; + + + break; + case 4 : + if ( (j != 0) ) + _cpc += 1; + + if ( (k != 0) ) + _cpc += 2; + + + break; + case 5 : + if ( (i != 0) ) + _cpc += 1; + + if ( (j != 0) ) + _cpc += 2; + + if ( (k != 0) ) + _cpc += 4; + + + break; + + } + { + int _lower; + int _mid; + int _upper; + _lower = _ckeys; + _upper = _ckeys + _klen - 1; + while ( true ) + { + if ( _upper < _lower ) + break; + + + _mid = _lower + ((_upper-_lower) >> 1); + if ( _cpc < (int)_foo_cond_keys[_mid ] ) + _upper = _mid - 1; + + else if ( _cpc > (int)_foo_cond_keys[_mid ] ) + _lower = _mid + 1; + + else + { + _cond += (int )(_mid - _ckeys); + { + _goto_targ = 3; + if (true) + continue _goto; + } + + } + + + } + + cs = 0; + { + _goto_targ = 4; + if (true) + continue _goto; + } + + } + + case 3: + cs = (int)_foo_cond_targs[_cond]; + if ( _foo_cond_actions[_cond] == 0 ) + { + _goto_targ = 4; + if (true) + continue _goto; + } + + _nbreak = 0; + switch ( _foo_cond_actions[_cond] ) { + case 8 : + { + System.out.print( " one\n" ); + + } + + break; + case 4 : + { + System.out.print( " two\n" ); + + } + + break; + case 6 : + { + System.out.print( " three\n" ); + + } + + break; + case 1 : + { + if ( (( data[p ])) == 48 ) + { + i = 0; + + } + else { + i = 1; + + } + + } + + break; + case 2 : + { + if ( (( data[p ])) == 48 ) + { + j = 0; + + } + else { + j = 1; + + } + + } + + break; + case 3 : + { + if ( (( data[p ])) == 48 ) + { + k = 0; + + } + else { + k = 1; + + } + + } + + break; + case 5 : + { + { + p+= 1; + _nbreak = 1; + + } + + } + + break; + case 9 : + { + System.out.print( " one\n" ); + + } + { + System.out.print( " two\n" ); + + } + + break; + case 10 : + { + System.out.print( " one\n" ); + + } + { + System.out.print( " three\n" ); + + } + + break; + case 7 : + { + System.out.print( " two\n" ); + + } + { + System.out.print( " three\n" ); + + } + + break; + case 11 : + { + System.out.print( " one\n" ); + + } + { + System.out.print( " two\n" ); + + } + { + System.out.print( " three\n" ); + + } + + break; + + } + if ( _nbreak == 1 ) + { + _goto_targ = 6; + if (true) + continue _goto; + } + + + case 4: + if ( cs == 0 ) + { + _goto_targ = 6; + if (true) + continue _goto; + } + + p += 1; + if ( p != pe ) + { + _goto_targ = 1; + if (true) + continue _goto; + } + + + case 5: + { + + } + + case 6: + { + + } + + + } + break; + } + + } + } + + void finish( ) + { + if ( cs >= foo_first_final ) + System.out.println( "ACCEPT" ); + else + System.out.println( "FAIL" ); + } + + static final String inp[] = { + "000abc\n", + "100abc\n", + "010abc\n", + "110abc\n", + "001abc\n", + "101abc\n", + "011abc\n", + "111abc\n", + }; + + static final int inplen = 8; + + public static void main (String[] args) + { + cond1_java machine = new cond1_java(); + for ( int i = 0; i < inplen; i++ ) { + machine.init(); + machine.exec( inp[i].toCharArray(), inp[i].length() ); + machine.finish(); + } + } +} |