# begin: ragel =begin class << self attr_accessor :_bel_trans_keys private :_bel_trans_keys, :_bel_trans_keys= end self._bel_trans_keys = [ 0, 0, 83, 115, 69, 101, 84, 116, 9, 32, 9, 122, 9, 122, 9, 61, 9, 32, 9, 123, 34, 92, 10, 10, 92, 92, 10, 122, 9, 122, 34, 92, 9, 125, 9, 125, 10, 10, 92, 92, 9, 125, 48, 122, 10, 122, 34, 34, 34, 92, 10, 10, 92, 92, 123, 123, 9, 122, 34, 92, 9, 125, 9, 125, 10, 10, 92, 92, 9, 125, 0, 0, 0, 0, 0, 0, 0, 0, 0 ] class << self attr_accessor :_bel_key_spans private :_bel_key_spans, :_bel_key_spans= end self._bel_key_spans = [ 0, 33, 33, 33, 24, 114, 114, 53, 24, 115, 59, 1, 1, 113, 114, 59, 117, 117, 1, 1, 117, 75, 113, 1, 59, 1, 1, 1, 114, 59, 117, 117, 1, 1, 117, 0, 0, 0, 0 ] class << self attr_accessor :_bel_index_offsets private :_bel_index_offsets, :_bel_index_offsets= end self._bel_index_offsets = [ 0, 0, 34, 68, 102, 127, 242, 357, 411, 436, 552, 612, 614, 616, 730, 845, 905, 1023, 1141, 1143, 1145, 1263, 1339, 1453, 1455, 1515, 1517, 1519, 1521, 1636, 1696, 1814, 1932, 1934, 1936, 2054, 2055, 2056, 2057 ] class << self attr_accessor :_bel_indicies private :_bel_indicies, :_bel_indicies= end self._bel_indicies = [ 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, 0, 1, 2, 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, 1, 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, 3, 1, 4, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 4, 1, 6, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 6, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 5, 5, 5, 5, 5, 5, 5, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 5, 5, 5, 5, 7, 5, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 5, 8, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 8, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 5, 5, 5, 5, 5, 5, 5, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 5, 5, 5, 5, 9, 5, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 5, 10, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 10, 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, 11, 1, 12, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 12, 1, 12, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 12, 13, 14, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 13, 13, 13, 13, 13, 13, 13, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 13, 13, 13, 13, 15, 13, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 16, 13, 18, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 19, 17, 21, 20, 19, 17, 22, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 5, 5, 5, 5, 5, 5, 5, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 5, 5, 5, 5, 23, 5, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 5, 25, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 25, 24, 26, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 24, 24, 24, 24, 24, 24, 24, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 24, 24, 24, 24, 27, 24, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 24, 29, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 30, 28, 32, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 32, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 33, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 34, 31, 35, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 35, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 36, 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, 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, 37, 1, 38, 1, 30, 28, 40, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 40, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 41, 39, 39, 39, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 39, 39, 39, 39, 39, 39, 39, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 39, 39, 39, 39, 42, 39, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 39, 39, 43, 39, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 44, 44, 44, 44, 44, 44, 44, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 44, 44, 44, 44, 45, 44, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 44, 46, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 44, 44, 44, 44, 44, 44, 44, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 44, 44, 44, 44, 47, 44, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 44, 49, 48, 51, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 52, 50, 53, 48, 52, 50, 55, 54, 57, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 57, 56, 58, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 56, 56, 56, 56, 56, 56, 56, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 56, 56, 56, 56, 59, 56, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 56, 61, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 62, 60, 64, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 64, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 65, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 66, 63, 67, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 67, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 68, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 69, 54, 70, 54, 62, 60, 72, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 72, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 73, 71, 71, 71, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 71, 71, 71, 71, 71, 71, 71, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 71, 71, 71, 71, 74, 71, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 71, 71, 75, 71, 1, 1, 1, 1, 0 ] class << self attr_accessor :_bel_trans_targs private :_bel_trans_targs, :_bel_trans_targs= end self._bel_trans_targs = [ 2, 0, 3, 4, 5, 0, 5, 6, 7, 6, 7, 8, 9, 0, 10, 13, 14, 10, 11, 12, 0, 35, 35, 13, 0, 14, 15, 20, 15, 16, 19, 0, 17, 14, 18, 17, 14, 18, 35, 0, 17, 14, 20, 18, 0, 22, 36, 22, 0, 24, 24, 25, 26, 37, 0, 28, 0, 28, 29, 34, 29, 30, 33, 0, 31, 28, 32, 31, 28, 32, 38, 0, 31, 28, 34, 32 ] class << self attr_accessor :_bel_trans_actions private :_bel_trans_actions, :_bel_trans_actions= end self._bel_trans_actions = [ 0, 0, 0, 0, 1, 2, 0, 3, 4, 5, 0, 0, 0, 6, 7, 3, 8, 10, 10, 10, 9, 11, 12, 5, 13, 0, 7, 3, 10, 10, 10, 14, 15, 16, 17, 0, 18, 19, 20, 21, 22, 23, 5, 24, 25, 3, 26, 5, 27, 7, 10, 10, 10, 28, 29, 8, 30, 0, 7, 3, 10, 10, 10, 31, 15, 16, 17, 0, 18, 19, 32, 33, 22, 23, 5, 24 ] class << self attr_accessor :_bel_eof_actions private :_bel_eof_actions, :_bel_eof_actions= end self._bel_eof_actions = [ 0, 0, 0, 0, 0, 2, 2, 0, 0, 6, 9, 9, 9, 2, 13, 14, 14, 0, 0, 14, 21, 25, 25, 27, 27, 27, 27, 29, 30, 31, 31, 29, 29, 31, 33, 0, 0, 0, 0 ] class << self attr_accessor :bel_start end self.bel_start = 1; class << self attr_accessor :bel_first_final end self.bel_first_final = 35; class << self attr_accessor :bel_error end self.bel_error = 0; class << self attr_accessor :bel_en_ident end self.bel_en_ident = 21; class << self attr_accessor :bel_en_string end self.bel_en_string = 23; class << self attr_accessor :bel_en_list end self.bel_en_list = 27; class << self attr_accessor :bel_en_set end self.bel_en_set = 1; begin p ||= 0 pe ||= data.length cs = bel_start end begin testEof = false _slen, _trans, _keys, _inds, _acts, _nacts = nil _goto_level = 0 _resume = 10 _eof_trans = 15 _again = 20 _test_eof = 30 _out = 40 while true if _goto_level <= 0 if p == pe _goto_level = _test_eof next end if cs == 0 _goto_level = _out next end end if _goto_level <= _resume _keys = cs << 1 _inds = _bel_index_offsets[cs] _slen = _bel_key_spans[cs] _wide = data[p].ord _trans = if ( _slen > 0 && _bel_trans_keys[_keys] <= _wide && _wide <= _bel_trans_keys[_keys + 1] ) then _bel_indicies[ _inds + _wide - _bel_trans_keys[_keys] ] else _bel_indicies[ _inds + _slen ] end cs = _bel_trans_targs[_trans] if _bel_trans_actions[_trans] != 0 case _bel_trans_actions[_trans] when 5 then begin (@buffers[:ident] ||= []) << data[p].ord end when 2 then begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end when 10 then begin (@buffers[:string] ||= []) << data[p].ord end when 9 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end when 18 then begin @buffers.delete(:string) @buffers.delete(:ident) end when 8 then begin @buffers[:list] = list() end when 19 then begin #TODO: Mark @buffers[:list] as complete. end when 32 then begin yield @buffers[:list] end when 29 then begin @buffers[:list] ||= list() yield @buffers[:list] end when 1 then begin @buffers[:set] = set() end when 3 then begin @buffers[:ident] = [] end begin (@buffers[:ident] ||= []) << data[p].ord end when 26 then begin @buffers[:ident] = identifier(utf8_string(@buffers[:ident])) end begin yield @buffers[:ident] end when 4 then begin @buffers[:ident] = identifier(utf8_string(@buffers[:ident])) end begin @buffers[:set] = @buffers[:set] << name(@buffers[:ident]) end when 25 then begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin @buffers[:ident] ||= [] yield @buffers[:ident] end when 7 then begin @buffers[:string] = [] end begin (@buffers[:string] ||= []) << data[p].ord end when 28 then begin @buffers[:string] = string(utf8_string(@buffers[:string])) end begin yield @buffers[:string] end when 6 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end when 27 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin @buffers[:string] ||= [] yield @buffers[:string] end when 20 then begin @buffers[:set] = @buffers[:set] << value(@buffers[:list]) end begin yield @buffers[:set] end when 22 then begin @buffers[:ident] = identifier(utf8_string(@buffers[:ident])) end begin @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end when 12 then begin @buffers[:ident] = identifier(utf8_string(@buffers[:ident])) end begin @buffers[:set] = @buffers[:set] << value(@buffers[:ident]) end begin yield @buffers[:set] end when 21 then begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin #TODO: Mark @buffers[:list_arg] identifier as error. @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end when 15 then begin @buffers[:string] = string(utf8_string(@buffers[:string])) end begin @buffers[:list_arg] = list_item(@buffers[:string]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end when 11 then begin @buffers[:string] = string(utf8_string(@buffers[:string])) end begin @buffers[:set] = @buffers[:set] << value(@buffers[:string]) end begin yield @buffers[:set] end when 14 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin #TODO: Mark @buffers[:list_arg] string as error. @buffers[:list_arg] = list_item(@buffers[:string]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end when 23 then begin @buffers[:ident] = identifier(utf8_string(@buffers[:ident])) end begin @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin @buffers.delete(:string) @buffers.delete(:ident) end when 24 then begin @buffers[:ident] = identifier(utf8_string(@buffers[:ident])) end begin @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin #TODO: Mark @buffers[:list] as complete. end when 33 then begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin #TODO: Mark @buffers[:list_arg] identifier as error. @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin @buffers[:list] ||= list() yield @buffers[:list] end when 16 then begin @buffers[:string] = string(utf8_string(@buffers[:string])) end begin @buffers[:list_arg] = list_item(@buffers[:string]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin @buffers.delete(:string) @buffers.delete(:ident) end when 17 then begin @buffers[:string] = string(utf8_string(@buffers[:string])) end begin @buffers[:list_arg] = list_item(@buffers[:string]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin #TODO: Mark @buffers[:list] as complete. end when 31 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin #TODO: Mark @buffers[:list_arg] string as error. @buffers[:list_arg] = list_item(@buffers[:string]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin @buffers[:list] ||= list() yield @buffers[:list] end when 13 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin #TODO: Mark @buffers[:list_arg] string as error. @buffers[:list_arg] = list_item(@buffers[:string]) end begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin #TODO: Mark @buffers[:list_arg] identifier as error. @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end when 30 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin #TODO: Mark @buffers[:list_arg] string as error. @buffers[:list_arg] = list_item(@buffers[:string]) end begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin #TODO: Mark @buffers[:list_arg] identifier as error. @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin @buffers[:list] ||= list() yield @buffers[:list] end end end end if _goto_level <= _again if cs == 0 _goto_level = _out next end p += 1 if p != pe _goto_level = _resume next end end if _goto_level <= _test_eof if p == eof case _bel_eof_actions[cs] when 2 then begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end when 9 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end when 29 then begin @buffers[:list] ||= list() yield @buffers[:list] end when 25 then begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin @buffers[:ident] ||= [] yield @buffers[:ident] end when 6 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end when 27 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin @buffers[:string] ||= [] yield @buffers[:string] end when 21 then begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin #TODO: Mark @buffers[:list_arg] identifier as error. @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end when 14 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin #TODO: Mark @buffers[:list_arg] string as error. @buffers[:list_arg] = list_item(@buffers[:string]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end when 33 then begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin #TODO: Mark @buffers[:list_arg] identifier as error. @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin @buffers[:list] ||= list() yield @buffers[:list] end when 31 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin #TODO: Mark @buffers[:list_arg] string as error. @buffers[:list_arg] = list_item(@buffers[:string]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin @buffers[:list] ||= list() yield @buffers[:list] end when 13 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin #TODO: Mark @buffers[:list_arg] string as error. @buffers[:list_arg] = list_item(@buffers[:string]) end begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin #TODO: Mark @buffers[:list_arg] identifier as error. @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end when 30 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin #TODO: Mark @buffers[:list_arg] string as error. @buffers[:list_arg] = list_item(@buffers[:string]) end begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin #TODO: Mark @buffers[:list_arg] identifier as error. @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin @buffers[:list] ||= list() yield @buffers[:list] end end end end if _goto_level <= _out break end end end class << self attr_accessor :_bel_trans_keys private :_bel_trans_keys, :_bel_trans_keys= end self._bel_trans_keys = [ 0, 0, 83, 115, 69, 101, 84, 116, 9, 32, 9, 122, 9, 122, 9, 61, 9, 32, 9, 123, 34, 92, 10, 10, 92, 92, 10, 122, 9, 122, 34, 92, 9, 125, 9, 125, 10, 10, 92, 92, 9, 125, 48, 122, 10, 122, 34, 34, 34, 92, 10, 10, 92, 92, 123, 123, 9, 122, 34, 92, 9, 125, 9, 125, 10, 10, 92, 92, 9, 125, 0, 0, 0, 0, 0, 0, 0, 0, 0 ] class << self attr_accessor :_bel_key_spans private :_bel_key_spans, :_bel_key_spans= end self._bel_key_spans = [ 0, 33, 33, 33, 24, 114, 114, 53, 24, 115, 59, 1, 1, 113, 114, 59, 117, 117, 1, 1, 117, 75, 113, 1, 59, 1, 1, 1, 114, 59, 117, 117, 1, 1, 117, 0, 0, 0, 0 ] class << self attr_accessor :_bel_index_offsets private :_bel_index_offsets, :_bel_index_offsets= end self._bel_index_offsets = [ 0, 0, 34, 68, 102, 127, 242, 357, 411, 436, 552, 612, 614, 616, 730, 845, 905, 1023, 1141, 1143, 1145, 1263, 1339, 1453, 1455, 1515, 1517, 1519, 1521, 1636, 1696, 1814, 1932, 1934, 1936, 2054, 2055, 2056, 2057 ] class << self attr_accessor :_bel_indicies private :_bel_indicies, :_bel_indicies= end self._bel_indicies = [ 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, 0, 1, 2, 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, 1, 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, 3, 1, 4, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 4, 1, 6, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 6, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 5, 5, 5, 5, 5, 5, 5, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 5, 5, 5, 5, 7, 5, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 5, 8, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 8, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 5, 5, 5, 5, 5, 5, 5, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 5, 5, 5, 5, 9, 5, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 5, 10, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 10, 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, 11, 1, 12, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 12, 1, 12, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 12, 13, 14, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 13, 13, 13, 13, 13, 13, 13, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 13, 13, 13, 13, 15, 13, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 16, 13, 18, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 19, 17, 21, 20, 19, 17, 22, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 5, 5, 5, 5, 5, 5, 5, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 5, 5, 5, 5, 23, 5, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 5, 25, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 25, 24, 26, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 24, 24, 24, 24, 24, 24, 24, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 24, 24, 24, 24, 27, 24, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 24, 29, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 30, 28, 32, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 32, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 33, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 34, 31, 35, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 35, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 36, 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, 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, 37, 1, 38, 1, 30, 28, 40, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 40, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 41, 39, 39, 39, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 39, 39, 39, 39, 39, 39, 39, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 39, 39, 39, 39, 42, 39, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 39, 39, 43, 39, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 44, 44, 44, 44, 44, 44, 44, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 44, 44, 44, 44, 45, 44, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 44, 46, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 44, 44, 44, 44, 44, 44, 44, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 44, 44, 44, 44, 47, 44, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 44, 49, 48, 51, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 52, 50, 53, 48, 52, 50, 55, 54, 57, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 57, 56, 58, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 56, 56, 56, 56, 56, 56, 56, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 56, 56, 56, 56, 59, 56, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 56, 61, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 62, 60, 64, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 64, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 65, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 66, 63, 67, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 67, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 68, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 69, 54, 70, 54, 62, 60, 72, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 72, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 73, 71, 71, 71, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 71, 71, 71, 71, 71, 71, 71, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 71, 71, 71, 71, 74, 71, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 71, 71, 75, 71, 1, 1, 1, 1, 0 ] class << self attr_accessor :_bel_trans_targs private :_bel_trans_targs, :_bel_trans_targs= end self._bel_trans_targs = [ 2, 0, 3, 4, 5, 0, 5, 6, 7, 6, 7, 8, 9, 0, 10, 13, 14, 10, 11, 12, 0, 35, 35, 13, 0, 14, 15, 20, 15, 16, 19, 0, 17, 14, 18, 17, 14, 18, 35, 0, 17, 14, 20, 18, 0, 22, 36, 22, 0, 24, 24, 25, 26, 37, 0, 28, 0, 28, 29, 34, 29, 30, 33, 0, 31, 28, 32, 31, 28, 32, 38, 0, 31, 28, 34, 32 ] class << self attr_accessor :_bel_trans_actions private :_bel_trans_actions, :_bel_trans_actions= end self._bel_trans_actions = [ 0, 0, 0, 0, 1, 2, 0, 3, 4, 5, 0, 0, 0, 6, 7, 3, 8, 10, 10, 10, 9, 11, 12, 5, 13, 0, 7, 3, 10, 10, 10, 14, 15, 16, 17, 0, 18, 19, 20, 21, 22, 23, 5, 24, 25, 3, 26, 5, 27, 7, 10, 10, 10, 28, 29, 8, 30, 0, 7, 3, 10, 10, 10, 31, 15, 16, 17, 0, 18, 19, 32, 33, 22, 23, 5, 24 ] class << self attr_accessor :_bel_eof_actions private :_bel_eof_actions, :_bel_eof_actions= end self._bel_eof_actions = [ 0, 0, 0, 0, 0, 2, 2, 0, 0, 6, 9, 9, 9, 2, 13, 14, 14, 0, 0, 14, 21, 25, 25, 27, 27, 27, 27, 29, 30, 31, 31, 29, 29, 31, 33, 0, 0, 0, 0 ] class << self attr_accessor :bel_start end self.bel_start = 1; class << self attr_accessor :bel_first_final end self.bel_first_final = 35; class << self attr_accessor :bel_error end self.bel_error = 0; class << self attr_accessor :bel_en_ident end self.bel_en_ident = 21; class << self attr_accessor :bel_en_string end self.bel_en_string = 23; class << self attr_accessor :bel_en_list end self.bel_en_list = 27; class << self attr_accessor :bel_en_set end self.bel_en_set = 1; begin p ||= 0 pe ||= data.length cs = bel_start end begin testEof = false _slen, _trans, _keys, _inds, _acts, _nacts = nil _goto_level = 0 _resume = 10 _eof_trans = 15 _again = 20 _test_eof = 30 _out = 40 while true if _goto_level <= 0 if p == pe _goto_level = _test_eof next end if cs == 0 _goto_level = _out next end end if _goto_level <= _resume _keys = cs << 1 _inds = _bel_index_offsets[cs] _slen = _bel_key_spans[cs] _wide = data[p].ord _trans = if ( _slen > 0 && _bel_trans_keys[_keys] <= _wide && _wide <= _bel_trans_keys[_keys + 1] ) then _bel_indicies[ _inds + _wide - _bel_trans_keys[_keys] ] else _bel_indicies[ _inds + _slen ] end cs = _bel_trans_targs[_trans] if _bel_trans_actions[_trans] != 0 case _bel_trans_actions[_trans] when 5 then begin (@buffers[:ident] ||= []) << data[p].ord end when 2 then begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end when 10 then begin (@buffers[:string] ||= []) << data[p].ord end when 9 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end when 18 then begin @buffers.delete(:string) @buffers.delete(:ident) end when 8 then begin @buffers[:list] = list() end when 19 then begin #TODO: Mark @buffers[:list] as complete. end when 32 then begin yield @buffers[:list] end when 29 then begin @buffers[:list] ||= list() yield @buffers[:list] end when 1 then begin @buffers[:set] = set() end when 3 then begin @buffers[:ident] = [] end begin (@buffers[:ident] ||= []) << data[p].ord end when 26 then begin @buffers[:ident] = identifier(utf8_string(@buffers[:ident])) end begin yield @buffers[:ident] end when 4 then begin @buffers[:ident] = identifier(utf8_string(@buffers[:ident])) end begin @buffers[:set] = @buffers[:set] << name(@buffers[:ident]) end when 25 then begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin @buffers[:ident] ||= [] yield @buffers[:ident] end when 7 then begin @buffers[:string] = [] end begin (@buffers[:string] ||= []) << data[p].ord end when 28 then begin @buffers[:string] = string(utf8_string(@buffers[:string])) end begin yield @buffers[:string] end when 6 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end when 27 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin @buffers[:string] ||= [] yield @buffers[:string] end when 20 then begin @buffers[:set] = @buffers[:set] << value(@buffers[:list]) end begin yield @buffers[:set] end when 22 then begin @buffers[:ident] = identifier(utf8_string(@buffers[:ident])) end begin @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end when 12 then begin @buffers[:ident] = identifier(utf8_string(@buffers[:ident])) end begin @buffers[:set] = @buffers[:set] << value(@buffers[:ident]) end begin yield @buffers[:set] end when 21 then begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin #TODO: Mark @buffers[:list_arg] identifier as error. @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end when 15 then begin @buffers[:string] = string(utf8_string(@buffers[:string])) end begin @buffers[:list_arg] = list_item(@buffers[:string]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end when 11 then begin @buffers[:string] = string(utf8_string(@buffers[:string])) end begin @buffers[:set] = @buffers[:set] << value(@buffers[:string]) end begin yield @buffers[:set] end when 14 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin #TODO: Mark @buffers[:list_arg] string as error. @buffers[:list_arg] = list_item(@buffers[:string]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end when 23 then begin @buffers[:ident] = identifier(utf8_string(@buffers[:ident])) end begin @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin @buffers.delete(:string) @buffers.delete(:ident) end when 24 then begin @buffers[:ident] = identifier(utf8_string(@buffers[:ident])) end begin @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin #TODO: Mark @buffers[:list] as complete. end when 33 then begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin #TODO: Mark @buffers[:list_arg] identifier as error. @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin @buffers[:list] ||= list() yield @buffers[:list] end when 16 then begin @buffers[:string] = string(utf8_string(@buffers[:string])) end begin @buffers[:list_arg] = list_item(@buffers[:string]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin @buffers.delete(:string) @buffers.delete(:ident) end when 17 then begin @buffers[:string] = string(utf8_string(@buffers[:string])) end begin @buffers[:list_arg] = list_item(@buffers[:string]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin #TODO: Mark @buffers[:list] as complete. end when 31 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin #TODO: Mark @buffers[:list_arg] string as error. @buffers[:list_arg] = list_item(@buffers[:string]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin @buffers[:list] ||= list() yield @buffers[:list] end when 13 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin #TODO: Mark @buffers[:list_arg] string as error. @buffers[:list_arg] = list_item(@buffers[:string]) end begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin #TODO: Mark @buffers[:list_arg] identifier as error. @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end when 30 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin #TODO: Mark @buffers[:list_arg] string as error. @buffers[:list_arg] = list_item(@buffers[:string]) end begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin #TODO: Mark @buffers[:list_arg] identifier as error. @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin @buffers[:list] ||= list() yield @buffers[:list] end end end end if _goto_level <= _again if cs == 0 _goto_level = _out next end p += 1 if p != pe _goto_level = _resume next end end if _goto_level <= _test_eof if p == eof case _bel_eof_actions[cs] when 2 then begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end when 9 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end when 29 then begin @buffers[:list] ||= list() yield @buffers[:list] end when 25 then begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin @buffers[:ident] ||= [] yield @buffers[:ident] end when 6 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end when 27 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin @buffers[:string] ||= [] yield @buffers[:string] end when 21 then begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin #TODO: Mark @buffers[:list_arg] identifier as error. @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end when 14 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin #TODO: Mark @buffers[:list_arg] string as error. @buffers[:list_arg] = list_item(@buffers[:string]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end when 33 then begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin #TODO: Mark @buffers[:list_arg] identifier as error. @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin @buffers[:list] ||= list() yield @buffers[:list] end when 31 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin #TODO: Mark @buffers[:list_arg] string as error. @buffers[:list_arg] = list_item(@buffers[:string]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin @buffers[:list] ||= list() yield @buffers[:list] end when 13 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin #TODO: Mark @buffers[:list_arg] string as error. @buffers[:list_arg] = list_item(@buffers[:string]) end begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin #TODO: Mark @buffers[:list_arg] identifier as error. @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end when 30 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin #TODO: Mark @buffers[:list_arg] string as error. @buffers[:list_arg] = list_item(@buffers[:string]) end begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin #TODO: Mark @buffers[:list_arg] identifier as error. @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin @buffers[:list] ||= list() yield @buffers[:list] end end end end if _goto_level <= _out break end end end class << self attr_accessor :_bel_trans_keys private :_bel_trans_keys, :_bel_trans_keys= end self._bel_trans_keys = [ 0, 0, 83, 115, 69, 101, 84, 116, 9, 32, 9, 122, 9, 122, 9, 61, 9, 32, 9, 123, 34, 92, 10, 10, 92, 92, 10, 122, 9, 122, 34, 92, 9, 125, 9, 125, 10, 10, 92, 92, 9, 125, 48, 122, 10, 122, 34, 34, 34, 92, 10, 10, 92, 92, 123, 123, 9, 122, 34, 92, 9, 125, 9, 125, 10, 10, 92, 92, 9, 125, 0, 0, 0, 0, 0, 0, 0, 0, 0 ] class << self attr_accessor :_bel_key_spans private :_bel_key_spans, :_bel_key_spans= end self._bel_key_spans = [ 0, 33, 33, 33, 24, 114, 114, 53, 24, 115, 59, 1, 1, 113, 114, 59, 117, 117, 1, 1, 117, 75, 113, 1, 59, 1, 1, 1, 114, 59, 117, 117, 1, 1, 117, 0, 0, 0, 0 ] class << self attr_accessor :_bel_index_offsets private :_bel_index_offsets, :_bel_index_offsets= end self._bel_index_offsets = [ 0, 0, 34, 68, 102, 127, 242, 357, 411, 436, 552, 612, 614, 616, 730, 845, 905, 1023, 1141, 1143, 1145, 1263, 1339, 1453, 1455, 1515, 1517, 1519, 1521, 1636, 1696, 1814, 1932, 1934, 1936, 2054, 2055, 2056, 2057 ] class << self attr_accessor :_bel_indicies private :_bel_indicies, :_bel_indicies= end self._bel_indicies = [ 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, 0, 1, 2, 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, 1, 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, 3, 1, 4, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 4, 1, 6, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 6, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 5, 5, 5, 5, 5, 5, 5, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 5, 5, 5, 5, 7, 5, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 5, 8, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 8, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 5, 5, 5, 5, 5, 5, 5, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 5, 5, 5, 5, 9, 5, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 5, 10, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 10, 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, 11, 1, 12, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 12, 1, 12, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 12, 13, 14, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 13, 13, 13, 13, 13, 13, 13, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 13, 13, 13, 13, 15, 13, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 16, 13, 18, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 19, 17, 21, 20, 19, 17, 22, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 5, 5, 5, 5, 5, 5, 5, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 5, 5, 5, 5, 23, 5, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 5, 25, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 25, 24, 26, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 24, 24, 24, 24, 24, 24, 24, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 24, 24, 24, 24, 27, 24, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 24, 29, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 30, 28, 32, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 32, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 33, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 34, 31, 35, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 35, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 36, 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, 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, 37, 1, 38, 1, 30, 28, 40, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 40, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 41, 39, 39, 39, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 39, 39, 39, 39, 39, 39, 39, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 39, 39, 39, 39, 42, 39, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 39, 39, 43, 39, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 44, 44, 44, 44, 44, 44, 44, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 44, 44, 44, 44, 45, 44, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 44, 46, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 44, 44, 44, 44, 44, 44, 44, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 44, 44, 44, 44, 47, 44, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 44, 49, 48, 51, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 52, 50, 53, 48, 52, 50, 55, 54, 57, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 57, 56, 58, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 56, 56, 56, 56, 56, 56, 56, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 56, 56, 56, 56, 59, 56, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 56, 61, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 62, 60, 64, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 64, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 65, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 66, 63, 67, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 67, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 68, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 69, 54, 70, 54, 62, 60, 72, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 72, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 73, 71, 71, 71, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 71, 71, 71, 71, 71, 71, 71, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 71, 71, 71, 71, 74, 71, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 71, 71, 75, 71, 1, 1, 1, 1, 0 ] class << self attr_accessor :_bel_trans_targs private :_bel_trans_targs, :_bel_trans_targs= end self._bel_trans_targs = [ 2, 0, 3, 4, 5, 0, 5, 6, 7, 6, 7, 8, 9, 0, 10, 13, 14, 10, 11, 12, 0, 35, 35, 13, 0, 14, 15, 20, 15, 16, 19, 0, 17, 14, 18, 17, 14, 18, 35, 0, 17, 14, 20, 18, 0, 22, 36, 22, 0, 24, 24, 25, 26, 37, 0, 28, 0, 28, 29, 34, 29, 30, 33, 0, 31, 28, 32, 31, 28, 32, 38, 0, 31, 28, 34, 32 ] class << self attr_accessor :_bel_trans_actions private :_bel_trans_actions, :_bel_trans_actions= end self._bel_trans_actions = [ 0, 0, 0, 0, 1, 2, 0, 3, 4, 5, 0, 0, 0, 6, 7, 3, 8, 10, 10, 10, 9, 11, 12, 5, 13, 0, 7, 3, 10, 10, 10, 14, 15, 16, 17, 0, 18, 19, 20, 21, 22, 23, 5, 24, 25, 3, 26, 5, 27, 7, 10, 10, 10, 28, 29, 8, 30, 0, 7, 3, 10, 10, 10, 31, 15, 16, 17, 0, 18, 19, 32, 33, 22, 23, 5, 24 ] class << self attr_accessor :_bel_eof_actions private :_bel_eof_actions, :_bel_eof_actions= end self._bel_eof_actions = [ 0, 0, 0, 0, 0, 2, 2, 0, 0, 6, 9, 9, 9, 2, 13, 14, 14, 0, 0, 14, 21, 25, 25, 27, 27, 27, 27, 29, 30, 31, 31, 29, 29, 31, 33, 0, 0, 0, 0 ] class << self attr_accessor :bel_start end self.bel_start = 1; class << self attr_accessor :bel_first_final end self.bel_first_final = 35; class << self attr_accessor :bel_error end self.bel_error = 0; class << self attr_accessor :bel_en_ident end self.bel_en_ident = 21; class << self attr_accessor :bel_en_string end self.bel_en_string = 23; class << self attr_accessor :bel_en_list end self.bel_en_list = 27; class << self attr_accessor :bel_en_set end self.bel_en_set = 1; begin p ||= 0 pe ||= data.length cs = bel_start end begin testEof = false _slen, _trans, _keys, _inds, _acts, _nacts = nil _goto_level = 0 _resume = 10 _eof_trans = 15 _again = 20 _test_eof = 30 _out = 40 while true if _goto_level <= 0 if p == pe _goto_level = _test_eof next end if cs == 0 _goto_level = _out next end end if _goto_level <= _resume _keys = cs << 1 _inds = _bel_index_offsets[cs] _slen = _bel_key_spans[cs] _wide = data[p].ord _trans = if ( _slen > 0 && _bel_trans_keys[_keys] <= _wide && _wide <= _bel_trans_keys[_keys + 1] ) then _bel_indicies[ _inds + _wide - _bel_trans_keys[_keys] ] else _bel_indicies[ _inds + _slen ] end cs = _bel_trans_targs[_trans] if _bel_trans_actions[_trans] != 0 case _bel_trans_actions[_trans] when 5 then begin (@buffers[:ident] ||= []) << data[p].ord end when 2 then begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end when 10 then begin (@buffers[:string] ||= []) << data[p].ord end when 9 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end when 18 then begin @buffers.delete(:string) @buffers.delete(:ident) end when 8 then begin @buffers[:list] = list() end when 19 then begin #TODO: Mark @buffers[:list] as complete. end when 32 then begin yield @buffers[:list] end when 29 then begin @buffers[:list] ||= list() yield @buffers[:list] end when 1 then begin @buffers[:set] = set() end when 3 then begin @buffers[:ident] = [] end begin (@buffers[:ident] ||= []) << data[p].ord end when 26 then begin @buffers[:ident] = identifier(utf8_string(@buffers[:ident])) end begin yield @buffers[:ident] end when 4 then begin @buffers[:ident] = identifier(utf8_string(@buffers[:ident])) end begin @buffers[:set] = @buffers[:set] << name(@buffers[:ident]) end when 25 then begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin @buffers[:ident] ||= [] yield @buffers[:ident] end when 7 then begin @buffers[:string] = [] end begin (@buffers[:string] ||= []) << data[p].ord end when 28 then begin @buffers[:string] = string(utf8_string(@buffers[:string])) end begin yield @buffers[:string] end when 6 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end when 27 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin @buffers[:string] ||= [] yield @buffers[:string] end when 20 then begin @buffers[:set] = @buffers[:set] << value(@buffers[:list]) end begin yield @buffers[:set] end when 22 then begin @buffers[:ident] = identifier(utf8_string(@buffers[:ident])) end begin @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end when 12 then begin @buffers[:ident] = identifier(utf8_string(@buffers[:ident])) end begin @buffers[:set] = @buffers[:set] << value(@buffers[:ident]) end begin yield @buffers[:set] end when 21 then begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin #TODO: Mark @buffers[:list_arg] identifier as error. @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end when 15 then begin @buffers[:string] = string(utf8_string(@buffers[:string])) end begin @buffers[:list_arg] = list_item(@buffers[:string]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end when 11 then begin @buffers[:string] = string(utf8_string(@buffers[:string])) end begin @buffers[:set] = @buffers[:set] << value(@buffers[:string]) end begin yield @buffers[:set] end when 14 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin #TODO: Mark @buffers[:list_arg] string as error. @buffers[:list_arg] = list_item(@buffers[:string]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end when 23 then begin @buffers[:ident] = identifier(utf8_string(@buffers[:ident])) end begin @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin @buffers.delete(:string) @buffers.delete(:ident) end when 24 then begin @buffers[:ident] = identifier(utf8_string(@buffers[:ident])) end begin @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin #TODO: Mark @buffers[:list] as complete. end when 33 then begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin #TODO: Mark @buffers[:list_arg] identifier as error. @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin @buffers[:list] ||= list() yield @buffers[:list] end when 16 then begin @buffers[:string] = string(utf8_string(@buffers[:string])) end begin @buffers[:list_arg] = list_item(@buffers[:string]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin @buffers.delete(:string) @buffers.delete(:ident) end when 17 then begin @buffers[:string] = string(utf8_string(@buffers[:string])) end begin @buffers[:list_arg] = list_item(@buffers[:string]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin #TODO: Mark @buffers[:list] as complete. end when 31 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin #TODO: Mark @buffers[:list_arg] string as error. @buffers[:list_arg] = list_item(@buffers[:string]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin @buffers[:list] ||= list() yield @buffers[:list] end when 13 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin #TODO: Mark @buffers[:list_arg] string as error. @buffers[:list_arg] = list_item(@buffers[:string]) end begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin #TODO: Mark @buffers[:list_arg] identifier as error. @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end when 30 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin #TODO: Mark @buffers[:list_arg] string as error. @buffers[:list_arg] = list_item(@buffers[:string]) end begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin #TODO: Mark @buffers[:list_arg] identifier as error. @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin @buffers[:list] ||= list() yield @buffers[:list] end end end end if _goto_level <= _again if cs == 0 _goto_level = _out next end p += 1 if p != pe _goto_level = _resume next end end if _goto_level <= _test_eof if p == eof case _bel_eof_actions[cs] when 2 then begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end when 9 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end when 29 then begin @buffers[:list] ||= list() yield @buffers[:list] end when 25 then begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin @buffers[:ident] ||= [] yield @buffers[:ident] end when 6 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end when 27 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin @buffers[:string] ||= [] yield @buffers[:string] end when 21 then begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin #TODO: Mark @buffers[:list_arg] identifier as error. @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end when 14 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin #TODO: Mark @buffers[:list_arg] string as error. @buffers[:list_arg] = list_item(@buffers[:string]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end when 33 then begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin #TODO: Mark @buffers[:list_arg] identifier as error. @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin @buffers[:list] ||= list() yield @buffers[:list] end when 31 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin #TODO: Mark @buffers[:list_arg] string as error. @buffers[:list_arg] = list_item(@buffers[:string]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin @buffers[:list] ||= list() yield @buffers[:list] end when 13 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin #TODO: Mark @buffers[:list_arg] string as error. @buffers[:list_arg] = list_item(@buffers[:string]) end begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin #TODO: Mark @buffers[:list_arg] identifier as error. @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end when 30 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin #TODO: Mark @buffers[:list_arg] string as error. @buffers[:list_arg] = list_item(@buffers[:string]) end begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin #TODO: Mark @buffers[:list_arg] identifier as error. @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin @buffers[:list] ||= list() yield @buffers[:list] end end end end if _goto_level <= _out break end end end =end # end: ragel require_relative '../ast/node' require_relative '../mixin/buffer' require_relative '../nonblocking_io_wrapper' module BELParser module Parsers module BELScript module Set class << self MAX_LENGTH = 1024 * 128 # 128K def parse(content) return nil unless content Parser.new(content).each do |obj| yield obj end end end private class Parser include Enumerable include BELParser::Parsers::Buffer include BELParser::Parsers::AST::Sexp def initialize(content) @content = content # begin: ragel class << self attr_accessor :_bel_trans_keys private :_bel_trans_keys, :_bel_trans_keys= end self._bel_trans_keys = [ 0, 0, 83, 115, 69, 101, 84, 116, 9, 32, 9, 122, 9, 122, 9, 61, 9, 32, 9, 123, 34, 92, 10, 10, 92, 92, 10, 122, 9, 122, 34, 92, 9, 125, 9, 125, 10, 10, 92, 92, 9, 125, 48, 122, 10, 122, 34, 34, 34, 92, 10, 10, 92, 92, 123, 123, 9, 122, 34, 92, 9, 125, 9, 125, 10, 10, 92, 92, 9, 125, 0, 0, 0, 0, 0, 0, 0, 0, 0 ] class << self attr_accessor :_bel_key_spans private :_bel_key_spans, :_bel_key_spans= end self._bel_key_spans = [ 0, 33, 33, 33, 24, 114, 114, 53, 24, 115, 59, 1, 1, 113, 114, 59, 117, 117, 1, 1, 117, 75, 113, 1, 59, 1, 1, 1, 114, 59, 117, 117, 1, 1, 117, 0, 0, 0, 0 ] class << self attr_accessor :_bel_index_offsets private :_bel_index_offsets, :_bel_index_offsets= end self._bel_index_offsets = [ 0, 0, 34, 68, 102, 127, 242, 357, 411, 436, 552, 612, 614, 616, 730, 845, 905, 1023, 1141, 1143, 1145, 1263, 1339, 1453, 1455, 1515, 1517, 1519, 1521, 1636, 1696, 1814, 1932, 1934, 1936, 2054, 2055, 2056, 2057 ] class << self attr_accessor :_bel_indicies private :_bel_indicies, :_bel_indicies= end self._bel_indicies = [ 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, 0, 1, 2, 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, 1, 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, 3, 1, 4, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 4, 1, 6, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 6, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 5, 5, 5, 5, 5, 5, 5, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 5, 5, 5, 5, 7, 5, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 7, 5, 8, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 8, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 5, 5, 5, 5, 5, 5, 5, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 5, 5, 5, 5, 9, 5, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 9, 5, 10, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 10, 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, 11, 1, 12, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 12, 1, 12, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 12, 13, 14, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 13, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 13, 13, 13, 13, 13, 13, 13, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 13, 13, 13, 13, 15, 13, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 15, 16, 13, 18, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 17, 19, 17, 21, 20, 19, 17, 22, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 5, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 5, 5, 5, 5, 5, 5, 5, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 5, 5, 5, 5, 23, 5, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 23, 5, 25, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 25, 24, 26, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 24, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 24, 24, 24, 24, 24, 24, 24, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 24, 24, 24, 24, 27, 24, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 27, 24, 29, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 28, 30, 28, 32, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 32, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 33, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 31, 34, 31, 35, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 35, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 36, 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, 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, 37, 1, 38, 1, 30, 28, 40, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 40, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 39, 41, 39, 39, 39, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 39, 39, 39, 39, 39, 39, 39, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 39, 39, 39, 39, 42, 39, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 42, 39, 39, 43, 39, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 44, 44, 44, 44, 44, 44, 44, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 44, 44, 44, 44, 45, 44, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 45, 44, 46, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 44, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 44, 44, 44, 44, 44, 44, 44, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 44, 44, 44, 44, 47, 44, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 47, 44, 49, 48, 51, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 50, 52, 50, 53, 48, 52, 50, 55, 54, 57, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 57, 56, 58, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 56, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 56, 56, 56, 56, 56, 56, 56, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 56, 56, 56, 56, 59, 56, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 59, 56, 61, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 60, 62, 60, 64, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 64, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 65, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 63, 66, 63, 67, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 67, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 68, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 54, 69, 54, 70, 54, 62, 60, 72, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 72, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 71, 73, 71, 71, 71, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 71, 71, 71, 71, 71, 71, 71, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 71, 71, 71, 71, 74, 71, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 74, 71, 71, 75, 71, 1, 1, 1, 1, 0 ] class << self attr_accessor :_bel_trans_targs private :_bel_trans_targs, :_bel_trans_targs= end self._bel_trans_targs = [ 2, 0, 3, 4, 5, 0, 5, 6, 7, 6, 7, 8, 9, 0, 10, 13, 14, 10, 11, 12, 0, 35, 35, 13, 0, 14, 15, 20, 15, 16, 19, 0, 17, 14, 18, 17, 14, 18, 35, 0, 17, 14, 20, 18, 0, 22, 36, 22, 0, 24, 24, 25, 26, 37, 0, 28, 0, 28, 29, 34, 29, 30, 33, 0, 31, 28, 32, 31, 28, 32, 38, 0, 31, 28, 34, 32 ] class << self attr_accessor :_bel_trans_actions private :_bel_trans_actions, :_bel_trans_actions= end self._bel_trans_actions = [ 0, 0, 0, 0, 1, 2, 0, 3, 4, 5, 0, 0, 0, 6, 7, 3, 8, 10, 10, 10, 9, 11, 12, 5, 13, 0, 7, 3, 10, 10, 10, 14, 15, 16, 17, 0, 18, 19, 20, 21, 22, 23, 5, 24, 25, 3, 26, 5, 27, 7, 10, 10, 10, 28, 29, 8, 30, 0, 7, 3, 10, 10, 10, 31, 15, 16, 17, 0, 18, 19, 32, 33, 22, 23, 5, 24 ] class << self attr_accessor :_bel_eof_actions private :_bel_eof_actions, :_bel_eof_actions= end self._bel_eof_actions = [ 0, 0, 0, 0, 0, 2, 2, 0, 0, 6, 9, 9, 9, 2, 13, 14, 14, 0, 0, 14, 21, 25, 25, 27, 27, 27, 27, 29, 30, 31, 31, 29, 29, 31, 33, 0, 0, 0, 0 ] class << self attr_accessor :bel_start end self.bel_start = 1; class << self attr_accessor :bel_first_final end self.bel_first_final = 35; class << self attr_accessor :bel_error end self.bel_error = 0; class << self attr_accessor :bel_en_ident end self.bel_en_ident = 21; class << self attr_accessor :bel_en_string end self.bel_en_string = 23; class << self attr_accessor :bel_en_list end self.bel_en_list = 27; class << self attr_accessor :bel_en_set end self.bel_en_set = 1; # end: ragel end def each @buffers = {} data = @content.unpack('C*') p = 0 pe = data.length eof = data.length # begin: ragel begin p ||= 0 pe ||= data.length cs = bel_start end begin testEof = false _slen, _trans, _keys, _inds, _acts, _nacts = nil _goto_level = 0 _resume = 10 _eof_trans = 15 _again = 20 _test_eof = 30 _out = 40 while true if _goto_level <= 0 if p == pe _goto_level = _test_eof next end if cs == 0 _goto_level = _out next end end if _goto_level <= _resume _keys = cs << 1 _inds = _bel_index_offsets[cs] _slen = _bel_key_spans[cs] _wide = data[p].ord _trans = if ( _slen > 0 && _bel_trans_keys[_keys] <= _wide && _wide <= _bel_trans_keys[_keys + 1] ) then _bel_indicies[ _inds + _wide - _bel_trans_keys[_keys] ] else _bel_indicies[ _inds + _slen ] end cs = _bel_trans_targs[_trans] if _bel_trans_actions[_trans] != 0 case _bel_trans_actions[_trans] when 5 then begin (@buffers[:ident] ||= []) << data[p].ord end when 2 then begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end when 10 then begin (@buffers[:string] ||= []) << data[p].ord end when 9 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end when 18 then begin @buffers.delete(:string) @buffers.delete(:ident) end when 8 then begin @buffers[:list] = list() end when 19 then begin #TODO: Mark @buffers[:list] as complete. end when 32 then begin yield @buffers[:list] end when 29 then begin @buffers[:list] ||= list() yield @buffers[:list] end when 1 then begin @buffers[:set] = set() end when 3 then begin @buffers[:ident] = [] end begin (@buffers[:ident] ||= []) << data[p].ord end when 26 then begin @buffers[:ident] = identifier(utf8_string(@buffers[:ident])) end begin yield @buffers[:ident] end when 4 then begin @buffers[:ident] = identifier(utf8_string(@buffers[:ident])) end begin @buffers[:set] = @buffers[:set] << name(@buffers[:ident]) end when 25 then begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin @buffers[:ident] ||= [] yield @buffers[:ident] end when 7 then begin @buffers[:string] = [] end begin (@buffers[:string] ||= []) << data[p].ord end when 28 then begin @buffers[:string] = string(utf8_string(@buffers[:string])) end begin yield @buffers[:string] end when 6 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end when 27 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin @buffers[:string] ||= [] yield @buffers[:string] end when 20 then begin @buffers[:set] = @buffers[:set] << value(@buffers[:list]) end begin yield @buffers[:set] end when 22 then begin @buffers[:ident] = identifier(utf8_string(@buffers[:ident])) end begin @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end when 12 then begin @buffers[:ident] = identifier(utf8_string(@buffers[:ident])) end begin @buffers[:set] = @buffers[:set] << value(@buffers[:ident]) end begin yield @buffers[:set] end when 21 then begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin #TODO: Mark @buffers[:list_arg] identifier as error. @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end when 15 then begin @buffers[:string] = string(utf8_string(@buffers[:string])) end begin @buffers[:list_arg] = list_item(@buffers[:string]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end when 11 then begin @buffers[:string] = string(utf8_string(@buffers[:string])) end begin @buffers[:set] = @buffers[:set] << value(@buffers[:string]) end begin yield @buffers[:set] end when 14 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin #TODO: Mark @buffers[:list_arg] string as error. @buffers[:list_arg] = list_item(@buffers[:string]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end when 23 then begin @buffers[:ident] = identifier(utf8_string(@buffers[:ident])) end begin @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin @buffers.delete(:string) @buffers.delete(:ident) end when 24 then begin @buffers[:ident] = identifier(utf8_string(@buffers[:ident])) end begin @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin #TODO: Mark @buffers[:list] as complete. end when 33 then begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin #TODO: Mark @buffers[:list_arg] identifier as error. @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin @buffers[:list] ||= list() yield @buffers[:list] end when 16 then begin @buffers[:string] = string(utf8_string(@buffers[:string])) end begin @buffers[:list_arg] = list_item(@buffers[:string]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin @buffers.delete(:string) @buffers.delete(:ident) end when 17 then begin @buffers[:string] = string(utf8_string(@buffers[:string])) end begin @buffers[:list_arg] = list_item(@buffers[:string]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin #TODO: Mark @buffers[:list] as complete. end when 31 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin #TODO: Mark @buffers[:list_arg] string as error. @buffers[:list_arg] = list_item(@buffers[:string]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin @buffers[:list] ||= list() yield @buffers[:list] end when 13 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin #TODO: Mark @buffers[:list_arg] string as error. @buffers[:list_arg] = list_item(@buffers[:string]) end begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin #TODO: Mark @buffers[:list_arg] identifier as error. @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end when 30 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin #TODO: Mark @buffers[:list_arg] string as error. @buffers[:list_arg] = list_item(@buffers[:string]) end begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin #TODO: Mark @buffers[:list_arg] identifier as error. @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin @buffers[:list] ||= list() yield @buffers[:list] end end end end if _goto_level <= _again if cs == 0 _goto_level = _out next end p += 1 if p != pe _goto_level = _resume next end end if _goto_level <= _test_eof if p == eof case _bel_eof_actions[cs] when 2 then begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end when 9 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end when 29 then begin @buffers[:list] ||= list() yield @buffers[:list] end when 25 then begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin @buffers[:ident] ||= [] yield @buffers[:ident] end when 6 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end when 27 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin @buffers[:string] ||= [] yield @buffers[:string] end when 21 then begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin #TODO: Mark @buffers[:list_arg] identifier as error. @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end when 14 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin #TODO: Mark @buffers[:list_arg] string as error. @buffers[:list_arg] = list_item(@buffers[:string]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end when 33 then begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin #TODO: Mark @buffers[:list_arg] identifier as error. @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin @buffers[:list] ||= list() yield @buffers[:list] end when 31 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin #TODO: Mark @buffers[:list_arg] string as error. @buffers[:list_arg] = list_item(@buffers[:string]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin @buffers[:list] ||= list() yield @buffers[:list] end when 13 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin #TODO: Mark @buffers[:list_arg] string as error. @buffers[:list_arg] = list_item(@buffers[:string]) end begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin #TODO: Mark @buffers[:list_arg] identifier as error. @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end when 30 then begin @buffers[:string] ||= [] @buffers[:string] = string(utf8_string(@buffers[:string]).sub(/\n$/, '')) end begin #TODO: Mark @buffers[:list_arg] string as error. @buffers[:list_arg] = list_item(@buffers[:string]) end begin unless @buffers[:ident].is_a?(::AST::Node) @buffers[:ident] ||= [] @buffers[:ident] = identifier(utf8_string(@buffers[:ident]).sub(/\n$/, '')) end end begin #TODO: Mark @buffers[:list_arg] identifier as error. @buffers[:list_arg] = list_item(@buffers[:ident]) end begin # Append list argument if its value is not empty. list_arg_value = @buffers[:list_arg].children[0].children[0] if list_arg_value != '' @buffers[:list] <<= @buffers[:list_arg] end end begin @buffers[:list] ||= list() yield @buffers[:list] end end end end if _goto_level <= _out break end end end # end: ragel end end end end end end if __FILE__ == $0 $stdin.each_line do |line| BELParser::Parsers::BELScript::Set.parse(line) { |obj| puts obj.inspect } end end # vim: ft=ruby ts=2 sw=2: # encoding: utf-8