diff options
author | Adrian Thurston <thurston@colm.net> | 2019-09-09 09:33:46 -0600 |
---|---|---|
committer | Adrian Thurston <thurston@colm.net> | 2019-09-09 09:33:46 -0600 |
commit | c171cdda894fa59515d1bdc1e00cace185366e7f (patch) | |
tree | 3ca69dca58aee3bf7bd206cb056a4e1f9b6e1058 /test/cases/rlhc.d/case/curs1_go.go-Z-F1--goto-backend.in | |
parent | 05508d109059e400e093456ce50a1edfc6299f76 (diff) | |
download | colm-c171cdda894fa59515d1bdc1e00cace185366e7f.tar.gz |
lifted all test files to /test directory
Diffstat (limited to 'test/cases/rlhc.d/case/curs1_go.go-Z-F1--goto-backend.in')
-rw-r--r-- | test/cases/rlhc.d/case/curs1_go.go-Z-F1--goto-backend.in | 157 |
1 files changed, 157 insertions, 0 deletions
diff --git a/test/cases/rlhc.d/case/curs1_go.go-Z-F1--goto-backend.in b/test/cases/rlhc.d/case/curs1_go.go-Z-F1--goto-backend.in new file mode 100644 index 00000000..5cb9dfa7 --- /dev/null +++ b/test/cases/rlhc.d/case/curs1_go.go-Z-F1--goto-backend.in @@ -0,0 +1,157 @@ +host( "working/curs1_go.rl", 1 ) @{/* + * @@LANG: go + * @@GENERATED: true + */ + + package main + import "fmt" + + var return_to int ; + + + + + var cs int; + var blen int; + var buffer [1024] byte; + +}@ +array byte _curs1_trans_keys( 0, 11 ) = { u(1), u(0), u(0), u(3), u(10), u(10), u(6), u(6), u(10), u(10), u(8), u(8), u(5), u(5), u(4), u(4), u(7), u(7), u(6), u(6), u(5), u(5), u(9), u(9), u(11), u(11), u(7), u(7), u(1), u(0), u(1), u(0), u(1), u(0), u(1), u(0), u(0) }; + +array s8 _curs1_char_class( 0, 11 ) = { 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 2, 3, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 4, 5, 1, 1, 1, 1, 1, 1, 1, 1, 6, 7, 1, 1, 1, 8, 9, 10, 1, 11, 0 }; + +array s8 _curs1_index_offsets( 0, 16 ) = { 0, 0, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 16, 16, 16, 0 }; + +array s8 _curs1_indicies( 0, 15 ) = { 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 0 }; + +array s8 _curs1_index_defaults( 0, 1 ) = { 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0 }; + +array s8 _curs1_trans_cond_spaces( -1, 0 ) = { -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, -1, 0 }; + +array s8 _curs1_cond_targs( 0, 17 ) = { 14, 0, 14, 14, 3, 4, 5, 6, 7, 15, 9, 10, 16, 12, 13, 17, 0 }; + +array s8 _curs1_cond_actions( 0, 4 ) = { 0, 0, 1, 2, 0, 0, 0, 0, 0, 0, 0, 0, 3, 0, 0, 4, 0 }; + +array s8 _curs1_nfa_targs( 0, 0 ) = { 0, 0 }; + +array s8 _curs1_nfa_offsets( 0, 0 ) = { 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 }; + +array s8 _curs1_nfa_push_actions( 0, 0 ) = { 0, 0 }; + +array s8 _curs1_nfa_pop_trans( 0, 0 ) = { 0, 0 }; + +value int curs1_start = 1; +value int curs1_first_final = 14; +value int curs1_error = 0; + +value int curs1_en_unused = 2; +value int curs1_en_one = 8; +value int curs1_en_two = 11; +value int curs1_en_main = 1; + +host( "working/curs1_go.rl", 40 ) @{ + + func prepare() { + }@ + { + cs = cast(int)curs1_start; + } + host( "working/curs1_go.rl", 43 ) @{ + } + + func exec(data string) { + var p int = 0 + var pe int = len(data) + }@ + { + int _ps; + int _trans = 0; + index byte _keys; + index s8 _inds; + entry { + if ( p == pe ) + goto _test_eof; + if ( cs == 0 ) + goto _out; + label _resume { + _keys = offset( _curs1_trans_keys, (cs<<1) ); + _inds = offset( _curs1_indicies, _curs1_index_offsets[cs] ); + + if ( ( deref( data, p )) <= 119 && ( deref( data, p )) >= 10 ) + { + int _ic = cast(int)_curs1_char_class[cast(int)( deref( data, p )) - 10]; + if ( _ic <= cast(int)deref( _curs1_trans_keys, _keys+1 ) && _ic >= cast(int)deref( _curs1_trans_keys, _keys ) ) + _trans = cast(int)deref( _curs1_indicies, _inds + cast(int)( _ic - cast(int)deref( _curs1_trans_keys, _keys ) ) ); + else + _trans = cast(int)_curs1_index_defaults[cs]; + } + else { + _trans = cast(int)_curs1_index_defaults[cs]; + } + + goto _match_cond; + } + label _match_cond { + _ps = cs; + cs = cast(int)_curs1_cond_targs[_trans]; + + if ( _curs1_cond_actions[_trans] == 0 ) + goto _again; + + switch ( _curs1_cond_actions[_trans] ) { + case 3 { + host( "working/curs1_go.rl", 16 ) ${fmt.Print( "one\n" );${cs = host( "-", 1 ) ={return_to}=;}$ + + }$ + } + case 4 { + host( "working/curs1_go.rl", 20 ) ${fmt.Print( "two\n" );${cs = host( "-", 1 ) ={return_to}=;}$ + + }$ + } + case 1 { + host( "working/curs1_go.rl", 25 ) ${return_to = ={_ps}=; + ${cs = 8;}$}$ + } + case 2 { + host( "working/curs1_go.rl", 28 ) ${return_to = ={_ps}=; + ${cs = 11;}$}$ + } + } + + + } + label _again { + if ( cs == 0 ) + goto _out; + p+= 1; + if ( p != pe ) + goto _resume; + } + label _test_eof { {} + } + label _out { {} + } + } + } + host( "working/curs1_go.rl", 49 ) @{ + } + func finish() { + if cs >= curs1_first_final { + fmt.Println("ACCEPT") + } else { + fmt.Println("FAIL") + } + } + var inp []string = []string { + "1one2two1one\n", + }; + + func main() { + for _, data := range inp { + prepare() + exec(data) + finish() + } + } +}@
\ No newline at end of file |