class BELParser::Parsers::Common::List::Parser

Attributes

_bel_eof_actions[RW]
_bel_index_offsets[RW]
_bel_indicies[RW]
_bel_key_spans[RW]
_bel_trans_actions[RW]
_bel_trans_keys[RW]
_bel_trans_targs[RW]
bel_en_ident_node[RW]
bel_en_list_node[RW]
bel_en_string_node[RW]
bel_error[RW]
bel_first_final[RW]
bel_start[RW]

Public Class Methods

new(content) click to toggle source
# File lib/bel_parser/parsers/common/list.rb, line 1830
          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, 123, 123, 9, 34, 
        34, 92, 34, 92, 9, 
        122, 0, 0, 48, 122, 
        9, 34, 34, 92, 34, 92, 
        0, 0, 9, 125, 9, 
        125, 9, 34, 9, 125, 
        9, 125, 0, 0, 9, 125, 
        10, 10, 10, 122, 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, 1, 26, 59, 59, 114, 0, 75, 
        26, 59, 59, 0, 117, 117, 26, 117, 
        117, 0, 117, 1, 113, 0, 0
]

class << self
        attr_accessor :_bel_index_offsets
        private :_bel_index_offsets, :_bel_index_offsets=
end
self._bel_index_offsets = [
        0, 0, 2, 29, 89, 149, 264, 265, 
        341, 368, 428, 488, 489, 607, 725, 752, 
        870, 988, 989, 1107, 1109, 1223, 1224
]

class << self
        attr_accessor :_bel_indicies
        private :_bel_indicies, :_bel_indicies=
end
self._bel_indicies = [
        0, 1, 3, 3, 3, 3, 3, 2, 
        2, 2, 2, 2, 2, 2, 2, 2, 
        2, 2, 2, 2, 2, 2, 2, 2, 
        2, 3, 2, 4, 2, 6, 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, 5, 5, 5, 5, 5, 
        5, 5, 5, 5, 5, 5, 5, 5, 
        5, 5, 5, 5, 5, 5, 5, 7, 
        5, 9, 8, 8, 8, 8, 8, 8, 
        8, 8, 8, 8, 8, 8, 8, 8, 
        8, 8, 8, 8, 8, 8, 8, 8, 
        8, 8, 8, 8, 8, 8, 8, 8, 
        8, 8, 8, 8, 8, 8, 8, 8, 
        8, 8, 8, 8, 8, 8, 8, 8, 
        8, 8, 8, 8, 8, 8, 8, 8, 
        8, 8, 8, 10, 8, 12, 3, 3, 
        3, 3, 11, 11, 11, 11, 11, 11, 
        11, 11, 11, 11, 11, 11, 11, 11, 
        11, 11, 11, 11, 12, 11, 4, 11, 
        11, 11, 11, 11, 11, 11, 11, 11, 
        11, 11, 11, 11, 13, 13, 13, 13, 
        13, 13, 13, 13, 13, 13, 11, 11, 
        11, 11, 11, 11, 11, 13, 13, 13, 
        13, 13, 13, 13, 13, 13, 13, 13, 
        13, 13, 13, 13, 13, 13, 13, 13, 
        13, 13, 13, 13, 13, 13, 13, 11, 
        11, 11, 11, 13, 11, 13, 13, 13, 
        13, 13, 13, 13, 13, 13, 13, 13, 
        13, 13, 13, 13, 13, 13, 13, 13, 
        13, 13, 13, 13, 13, 13, 13, 11, 
        8, 14, 14, 14, 14, 14, 14, 14, 
        14, 14, 14, 1, 1, 1, 1, 1, 
        1, 1, 14, 14, 14, 14, 14, 14, 
        14, 14, 14, 14, 14, 14, 14, 14, 
        14, 14, 14, 14, 14, 14, 14, 14, 
        14, 14, 14, 14, 1, 1, 1, 1, 
        14, 1, 14, 14, 14, 14, 14, 14, 
        14, 14, 14, 14, 14, 14, 14, 14, 
        14, 14, 14, 14, 14, 14, 14, 14, 
        14, 14, 14, 14, 1, 16, 16, 16, 
        16, 16, 15, 15, 15, 15, 15, 15, 
        15, 15, 15, 15, 15, 15, 15, 15, 
        15, 15, 15, 15, 16, 15, 17, 15, 
        19, 18, 18, 18, 18, 18, 18, 18, 
        18, 18, 18, 18, 18, 18, 18, 18, 
        18, 18, 18, 18, 18, 18, 18, 18, 
        18, 18, 18, 18, 18, 18, 18, 18, 
        18, 18, 18, 18, 18, 18, 18, 18, 
        18, 18, 18, 18, 18, 18, 18, 18, 
        18, 18, 18, 18, 18, 18, 18, 18, 
        18, 18, 20, 18, 22, 21, 21, 21, 
        21, 21, 21, 21, 21, 21, 21, 21, 
        21, 21, 21, 21, 21, 21, 21, 21, 
        21, 21, 21, 21, 21, 21, 21, 21, 
        21, 21, 21, 21, 21, 21, 21, 21, 
        21, 21, 21, 21, 21, 21, 21, 21, 
        21, 21, 21, 21, 21, 21, 21, 21, 
        21, 21, 21, 21, 21, 21, 23, 21, 
        21, 24, 25, 26, 26, 26, 11, 11, 
        11, 11, 11, 11, 11, 11, 11, 11, 
        11, 11, 11, 11, 11, 11, 11, 11, 
        24, 11, 27, 11, 11, 11, 11, 11, 
        11, 11, 11, 11, 11, 11, 11, 11, 
        28, 28, 28, 28, 28, 28, 28, 28, 
        28, 28, 11, 11, 11, 11, 11, 11, 
        11, 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, 11, 11, 11, 11, 28, 
        11, 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, 11, 11, 29, 11, 30, 
        31, 3, 3, 3, 11, 11, 11, 11, 
        11, 11, 11, 11, 11, 11, 11, 11, 
        11, 11, 11, 11, 11, 11, 30, 11, 
        4, 11, 11, 11, 11, 11, 11, 11, 
        11, 11, 11, 11, 11, 11, 13, 13, 
        13, 13, 13, 13, 13, 13, 13, 13, 
        11, 11, 11, 11, 11, 11, 11, 13, 
        13, 13, 13, 13, 13, 13, 13, 13, 
        13, 13, 13, 13, 13, 13, 13, 13, 
        13, 13, 13, 13, 13, 13, 13, 13, 
        13, 11, 11, 11, 11, 13, 11, 13, 
        13, 13, 13, 13, 13, 13, 13, 13, 
        13, 13, 13, 13, 13, 13, 13, 13, 
        13, 13, 13, 13, 13, 13, 13, 13, 
        13, 11, 11, 32, 11, 3, 3, 3, 
        3, 3, 2, 2, 2, 2, 2, 2, 
        2, 2, 2, 2, 2, 2, 2, 2, 
        2, 2, 2, 2, 3, 2, 4, 2, 
        33, 34, 2, 2, 2, 2, 2, 2, 
        2, 2, 2, 2, 2, 2, 2, 2, 
        2, 2, 2, 2, 2, 2, 2, 33, 
        2, 2, 2, 2, 2, 2, 2, 2, 
        2, 2, 2, 35, 2, 2, 2, 2, 
        2, 2, 2, 2, 2, 2, 2, 2, 
        2, 2, 2, 2, 2, 2, 2, 2, 
        2, 2, 2, 2, 2, 2, 2, 2, 
        2, 2, 2, 2, 2, 2, 2, 2, 
        2, 2, 2, 2, 2, 2, 2, 2, 
        2, 2, 2, 2, 2, 2, 2, 2, 
        2, 2, 2, 2, 2, 2, 2, 2, 
        2, 2, 2, 2, 2, 2, 2, 2, 
        2, 2, 2, 2, 2, 2, 2, 2, 
        2, 2, 2, 2, 36, 2, 37, 38, 
        1, 1, 1, 1, 1, 1, 1, 1, 
        1, 1, 1, 1, 1, 1, 1, 1, 
        1, 1, 1, 1, 1, 37, 1, 1, 
        1, 1, 1, 1, 1, 1, 1, 1, 
        1, 12, 1, 1, 1, 1, 1, 1, 
        1, 1, 1, 1, 1, 1, 1, 1, 
        1, 1, 1, 1, 1, 1, 1, 1, 
        1, 1, 1, 1, 1, 1, 1, 1, 
        1, 1, 1, 1, 1, 1, 1, 1, 
        1, 1, 1, 1, 1, 1, 1, 1, 
        1, 1, 1, 1, 1, 1, 1, 1, 
        1, 1, 1, 1, 1, 1, 1, 1, 
        1, 1, 1, 1, 1, 1, 1, 1, 
        1, 1, 1, 1, 1, 1, 1, 1, 
        1, 1, 32, 1, 1, 40, 41, 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, 
        42, 39, 39, 39, 43, 43, 43, 43, 
        43, 43, 43, 43, 43, 43, 39, 39, 
        39, 39, 39, 39, 39, 43, 43, 43, 
        43, 43, 43, 43, 43, 43, 43, 43, 
        43, 43, 43, 43, 43, 43, 43, 43, 
        43, 43, 43, 43, 43, 43, 43, 39, 
        39, 39, 39, 43, 39, 43, 43, 43, 
        43, 43, 43, 43, 43, 43, 43, 43, 
        43, 43, 43, 43, 43, 43, 43, 43, 
        43, 43, 43, 43, 43, 43, 43, 39, 
        39, 44, 39, 45, 1, 47, 46, 46, 
        46, 46, 46, 46, 46, 46, 46, 46, 
        46, 46, 46, 46, 46, 46, 46, 46, 
        46, 46, 46, 46, 46, 46, 46, 46, 
        46, 46, 46, 46, 46, 46, 46, 46, 
        46, 46, 46, 48, 48, 48, 48, 48, 
        48, 48, 48, 48, 48, 46, 46, 46, 
        46, 46, 46, 46, 48, 48, 48, 48, 
        48, 48, 48, 48, 48, 48, 48, 48, 
        48, 48, 48, 48, 48, 48, 48, 48, 
        48, 48, 48, 48, 48, 48, 46, 46, 
        46, 46, 48, 46, 48, 48, 48, 48, 
        48, 48, 48, 48, 48, 48, 48, 48, 
        48, 48, 48, 48, 48, 48, 48, 48, 
        48, 48, 48, 48, 48, 48, 46, 46, 
        15, 0
]

class << self
        attr_accessor :_bel_trans_targs
        private :_bel_trans_targs, :_bel_trans_targs=
end
self._bel_trans_targs = [
        12, 0, 0, 2, 3, 4, 15, 6, 
        4, 15, 6, 0, 5, 18, 20, 0, 
        8, 9, 10, 22, 11, 10, 22, 11, 
        13, 14, 2, 3, 18, 19, 13, 14, 
        19, 16, 17, 5, 19, 16, 17, 0, 
        16, 17, 5, 18, 19, 17, 0, 21, 
        20
]

class << self
        attr_accessor :_bel_trans_actions
        private :_bel_trans_actions, :_bel_trans_actions=
end
self._bel_trans_actions = [
        0, 0, 2, 0, 0, 4, 5, 4, 
        0, 6, 0, 8, 0, 9, 9, 11, 
        0, 0, 4, 13, 4, 0, 14, 0, 
        16, 16, 16, 16, 17, 16, 0, 0, 
        0, 21, 21, 21, 21, 0, 0, 24, 
        25, 25, 25, 0, 25, 27, 29, 30, 
        0
]

class << self
        attr_accessor :_bel_eof_actions
        private :_bel_eof_actions, :_bel_eof_actions=
end
self._bel_eof_actions = [
        0, 0, 1, 3, 3, 7, 3, 0, 
        10, 12, 12, 12, 15, 18, 19, 20, 
        22, 22, 23, 26, 28, 31, 0
]

class << self
        attr_accessor :bel_start
end
self.bel_start = 1;
class << self
        attr_accessor :bel_first_final
end
self.bel_first_final = 12;
class << self
        attr_accessor :bel_error
end
self.bel_error = 0;

class << self
        attr_accessor :bel_en_ident_node
end
self.bel_en_ident_node = 7;
class << self
        attr_accessor :bel_en_string_node
end
self.bel_en_string_node = 8;
class << self
        attr_accessor :bel_en_list_node
end
self.bel_en_list_node = 1;


      # end: ragel
          end

Public Instance Methods

each() { |ast_node| ... } click to toggle source
# File lib/bel_parser/parsers/common/list.rb, line 2099
          def each
            @buffers      = {}
            @incomplete   = {}
            @list_opened  = false
            @list_closed  = false
            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 9 then
                begin

    trace('IDENTIFIER start_identifier')
    @identifier_started = true
    id_start = p;
                end
        when 30 then
                begin

    trace('IDENTIFIER end_identifier')
    id_end = p
    chars = data[id_start...id_end]
    completed = !chars.empty?
    ast_node = identifier(utf8_string(chars), complete: completed, character_range: [id_start, id_end])
    @buffers[:ident] = ast_node
                end
        when 24 then
                begin

    trace('IDENTIFIER an_ident_err')
    id_end = p
    chars = data[id_start...id_end]
    ast_node = identifier(utf8_string(chars), complete: false, character_range: [id_start, id_end])
    @buffers[:ident] = ast_node
                end
        when 29 then
                begin

    trace('IDENTIFIER ident_node_err')
    id_end = p
    chars = data[id_start...id_end]
    ast_node = identifier(utf8_string(chars), complete: false, character_range: [id_start, id_end])
    yield ast_node
                end
        when 4 then
                begin

    trace('STRING start_string')
    @string_opened = true
    p_start = p
                end
        when 2 then
                begin

    trace('STRING a_string_err')
    p_end = p
    chars = data[p_start...p_end]
    ast_node = string(utf8_string(chars), complete: false, character_range: [p_start, p_end])
    @buffers[:string] = ast_node
                end
        when 11 then
                begin

    trace('STRING string_node_err')
    p_end = p
    chars = data[p_start...p_end]
    ast_node = string(utf8_string(chars), complete: false, character_range: [p_start, p_end])
    yield ast_node
                end
        when 16 then
                begin

    trace('LIST start_list')
    @list_opened = true
    @incomplete[:list] = list()
                end
        when 27 then
                begin

    trace('LIST stop_list')
    @list_closed = true
                end
        when 21 then
                begin

    trace('LIST add_string')
    string = @buffers.delete(:string)
    item = list_item(string, complete: string.complete)
    @incomplete[:list] <<= item
                end
        when 25 then
                begin

    trace('IDENTIFIER end_identifier')
    id_end = p
    chars = data[id_start...id_end]
    completed = !chars.empty?
    ast_node = identifier(utf8_string(chars), complete: completed, character_range: [id_start, id_end])
    @buffers[:ident] = ast_node
                end
                begin

    trace('LIST add_ident')
    ident = @buffers.delete(:ident)
    item = list_item(ident, complete: ident.complete)
    @incomplete[:list] <<= item
                end
        when 6 then
                begin

    trace('STRING stop_string')
    @string_closed = true
    p_end = p
                end
                begin

    trace('STRING string_end')
    completed = @string_opened && @string_closed
    chars = data[p_start...p_end]
    ast_node = string(utf8_string(chars), complete: true, character_range: [p_start, p_end])
    @buffers[:string] = ast_node
                end
        when 8 then
                begin

    trace('STRING a_string_err')
    p_end = p
    chars = data[p_start...p_end]
    ast_node = string(utf8_string(chars), complete: false, character_range: [p_start, p_end])
    @buffers[:string] = ast_node
                end
                begin

    trace('IDENTIFIER an_ident_err')
    id_end = p
    chars = data[id_start...id_end]
    ast_node = identifier(utf8_string(chars), complete: false, character_range: [id_start, id_end])
    @buffers[:ident] = ast_node
                end
        when 17 then
                begin

    trace('LIST start_list')
    @list_opened = true
    @incomplete[:list] = list()
                end
                begin

    trace('IDENTIFIER start_identifier')
    @identifier_started = true
    id_start = p;
                end
        when 5 then
                begin

    trace('STRING start_string')
    @string_opened = true
    p_start = p
                end
                begin

    trace('STRING stop_string')
    @string_closed = true
    p_end = p
                end
                begin

    trace('STRING string_end')
    completed = @string_opened && @string_closed
    chars = data[p_start...p_end]
    ast_node = string(utf8_string(chars), complete: true, character_range: [p_start, p_end])
    @buffers[:string] = ast_node
                end
        when 14 then
                begin

    trace('STRING stop_string')
    @string_closed = true
    p_end = p
                end
                begin

    trace('STRING string_end')
    completed = @string_opened && @string_closed
    chars = data[p_start...p_end]
    ast_node = string(utf8_string(chars), complete: true, character_range: [p_start, p_end])
    @buffers[:string] = ast_node
                end
                begin

    trace('STRING yield_string')
    yield @buffers[:string]
                end
        when 13 then
                begin

    trace('STRING start_string')
    @string_opened = true
    p_start = p
                end
                begin

    trace('STRING stop_string')
    @string_closed = true
    p_end = p
                end
                begin

    trace('STRING string_end')
    completed = @string_opened && @string_closed
    chars = data[p_start...p_end]
    ast_node = string(utf8_string(chars), complete: true, character_range: [p_start, p_end])
    @buffers[:string] = ast_node
                end
                begin

    trace('STRING yield_string')
    yield @buffers[:string]
                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 31 then
                begin

    trace('IDENTIFIER yield_identifier')
    yield @buffers[:ident]
                end
        when 28 then
                begin

    trace('IDENTIFIER end_identifier')
    id_end = p
    chars = data[id_start...id_end]
    completed = !chars.empty?
    ast_node = identifier(utf8_string(chars), complete: completed, character_range: [id_start, id_end])
    @buffers[:ident] = ast_node
                end
                begin

    trace('IDENTIFIER yield_identifier')
    yield @buffers[:ident]
                end
        when 1 then
                begin

    trace('STRING a_string_err')
    p_end = p
    chars = data[p_start...p_end]
    ast_node = string(utf8_string(chars), complete: false, character_range: [p_start, p_end])
    @buffers[:string] = ast_node
                end
                begin

    trace('LIST list_node_eof')
    list = @incomplete.delete(:list)
    string = @buffers.delete(:string)
    item = list_item(string, complete: string.complete)
    list <<= item
    list.complete = false
    yield list
                end
        when 10 then
                begin

    trace('STRING string_node_err')
    p_end = p
    chars = data[p_start...p_end]
    ast_node = string(utf8_string(chars), complete: false, character_range: [p_start, p_end])
    yield ast_node
                end
                begin

    trace('STRING string_node_eof')
    yield @buffers[:string]
                end
        when 22 then
                begin

    trace('LIST list_end')
    if @list_opened && @list_closed
      list = @incomplete.delete(:list)
      list.complete = true
    elsif !@list_closed
      list = @incomplete.delete(:list)
      list.complete = false
    end
    @buffers[:list] = list
                end
                begin

    trace('LIST yield_list')
    yield @buffers[:list]
                end
        when 3 then
                begin

    trace('STRING eof_string')
    p_end = p
    chars = data[p_start...p_end]
    ast_node = string(utf8_string(chars), complete: false, character_range: [p_start, p_end])
    @buffers[:string] = ast_node
                end
                begin

    trace('STRING a_string_err')
    p_end = p
    chars = data[p_start...p_end]
    ast_node = string(utf8_string(chars), complete: false, character_range: [p_start, p_end])
    @buffers[:string] = ast_node
                end
                begin

    trace('LIST list_node_eof')
    list = @incomplete.delete(:list)
    string = @buffers.delete(:string)
    item = list_item(string, complete: string.complete)
    list <<= item
    list.complete = false
    yield list
                end
        when 12 then
                begin

    trace('STRING eof_string')
    p_end = p
    chars = data[p_start...p_end]
    ast_node = string(utf8_string(chars), complete: false, character_range: [p_start, p_end])
    @buffers[:string] = ast_node
                end
                begin

    trace('STRING string_node_err')
    p_end = p
    chars = data[p_start...p_end]
    ast_node = string(utf8_string(chars), complete: false, character_range: [p_start, p_end])
    yield ast_node
                end
                begin

    trace('STRING string_node_eof')
    yield @buffers[:string]
                end
        when 26 then
                begin

    trace('LIST stop_list')
    @list_closed = true
                end
                begin

    trace('LIST list_end')
    if @list_opened && @list_closed
      list = @incomplete.delete(:list)
      list.complete = true
    elsif !@list_closed
      list = @incomplete.delete(:list)
      list.complete = false
    end
    @buffers[:list] = list
                end
                begin

    trace('LIST yield_list')
    yield @buffers[:list]
                end
        when 20 then
                begin

    trace('LIST add_string')
    string = @buffers.delete(:string)
    item = list_item(string, complete: string.complete)
    @incomplete[:list] <<= item
                end
                begin

    trace('LIST list_end')
    if @list_opened && @list_closed
      list = @incomplete.delete(:list)
      list.complete = true
    elsif !@list_closed
      list = @incomplete.delete(:list)
      list.complete = false
    end
    @buffers[:list] = list
                end
                begin

    trace('LIST yield_list')
    yield @buffers[:list]
                end
        when 19 then
                begin

    trace('LIST list_node_eof')
    list = @incomplete.delete(:list)
    string = @buffers.delete(:string)
    item = list_item(string, complete: string.complete)
    list <<= item
    list.complete = false
    yield list
                end
                begin

    trace('LIST list_end')
    if @list_opened && @list_closed
      list = @incomplete.delete(:list)
      list.complete = true
    elsif !@list_closed
      list = @incomplete.delete(:list)
      list.complete = false
    end
    @buffers[:list] = list
                end
                begin

    trace('LIST yield_list')
    yield @buffers[:list]
                end
        when 18 then
                begin

    trace('IDENTIFIER an_ident_eof')
    if @identifier_started
      id_end = p
      chars = data[id_start...id_end]
      completed = !chars.empty?
      ast_node = identifier(utf8_string(chars), complete: completed, character_range: [id_start, id_end])
      @buffers[:ident] = ast_node
    end
                end
                begin

    trace('LIST list_node_eof')
    list = @incomplete.delete(:list)
    string = @buffers.delete(:string)
    item = list_item(string, complete: string.complete)
    list <<= item
    list.complete = false
    yield list
                end
                begin

    trace('LIST list_end')
    if @list_opened && @list_closed
      list = @incomplete.delete(:list)
      list.complete = true
    elsif !@list_closed
      list = @incomplete.delete(:list)
      list.complete = false
    end
    @buffers[:list] = list
                end
                begin

    trace('LIST yield_list')
    yield @buffers[:list]
                end
        when 7 then
                begin

    trace('STRING a_string_err')
    p_end = p
    chars = data[p_start...p_end]
    ast_node = string(utf8_string(chars), complete: false, character_range: [p_start, p_end])
    @buffers[:string] = ast_node
                end
                begin

    trace('IDENTIFIER an_ident_eof')
    if @identifier_started
      id_end = p
      chars = data[id_start...id_end]
      completed = !chars.empty?
      ast_node = identifier(utf8_string(chars), complete: completed, character_range: [id_start, id_end])
      @buffers[:ident] = ast_node
    end
                end
                begin

    trace('IDENTIFIER an_ident_err')
    id_end = p
    chars = data[id_start...id_end]
    ast_node = identifier(utf8_string(chars), complete: false, character_range: [id_start, id_end])
    @buffers[:ident] = ast_node
                end
                begin

    trace('LIST list_node_eof')
    list = @incomplete.delete(:list)
    string = @buffers.delete(:string)
    item = list_item(string, complete: string.complete)
    list <<= item
    list.complete = false
    yield list
                end
        when 15 then
                begin

    trace('LIST start_list')
    @list_opened = true
    @incomplete[:list] = list()
                end
                begin

    trace('IDENTIFIER an_ident_eof')
    if @identifier_started
      id_end = p
      chars = data[id_start...id_end]
      completed = !chars.empty?
      ast_node = identifier(utf8_string(chars), complete: completed, character_range: [id_start, id_end])
      @buffers[:ident] = ast_node
    end
                end
                begin

    trace('LIST list_end')
    if @list_opened && @list_closed
      list = @incomplete.delete(:list)
      list.complete = true
    elsif !@list_closed
      list = @incomplete.delete(:list)
      list.complete = false
    end
    @buffers[:list] = list
                end
                begin

    trace('LIST yield_list')
    yield @buffers[:list]
                end
        when 23 then
                begin

    trace('IDENTIFIER end_identifier')
    id_end = p
    chars = data[id_start...id_end]
    completed = !chars.empty?
    ast_node = identifier(utf8_string(chars), complete: completed, character_range: [id_start, id_end])
    @buffers[:ident] = ast_node
                end
                begin

    trace('IDENTIFIER an_ident_eof')
    if @identifier_started
      id_end = p
      chars = data[id_start...id_end]
      completed = !chars.empty?
      ast_node = identifier(utf8_string(chars), complete: completed, character_range: [id_start, id_end])
      @buffers[:ident] = ast_node
    end
                end
                begin

    trace('LIST add_ident')
    ident = @buffers.delete(:ident)
    item = list_item(ident, complete: ident.complete)
    @incomplete[:list] <<= item
                end
                begin

    trace('LIST list_end')
    if @list_opened && @list_closed
      list = @incomplete.delete(:list)
      list.complete = true
    elsif !@list_closed
      list = @incomplete.delete(:list)
      list.complete = false
    end
    @buffers[:list] = list
                end
                begin

    trace('LIST yield_list')
    yield @buffers[:list]
                end
          end
        end

        end
        if _goto_level <= _out
                break
        end
end
        end

      # end: ragel
          end