class BELParser::Parsers::BELScript::Unset::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_unset_ast_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/bel_script/unset.rb, line 399
          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, 85, 117, 78, 110, 
        83, 115, 69, 101, 84, 
        116, 48, 122, 9, 122, 
        48, 122, 10, 122, 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, 33, 33, 75, 114, 
        75, 113, 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, 136, 170, 246, 
        361, 437, 551
]

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, 1, 1, 1, 
        1, 1, 1, 1, 1, 1, 4, 1, 
        5, 1, 1, 1, 1, 1, 1, 1, 
        1, 1, 1, 1, 1, 1, 1, 1, 
        1, 1, 1, 1, 1, 1, 1, 1, 
        1, 1, 1, 1, 1, 1, 1, 1, 
        5, 1, 6, 6, 6, 6, 6, 6, 
        6, 6, 6, 6, 1, 1, 1, 1, 
        1, 1, 1, 6, 6, 6, 6, 6, 
        6, 6, 6, 6, 6, 6, 6, 6, 
        6, 6, 6, 6, 6, 6, 6, 6, 
        6, 6, 6, 6, 6, 1, 1, 1, 
        1, 6, 1, 6, 6, 6, 6, 6, 
        6, 6, 6, 6, 6, 6, 6, 6, 
        6, 6, 6, 6, 6, 6, 6, 6, 
        6, 6, 6, 6, 6, 1, 5, 7, 
        7, 7, 7, 7, 7, 7, 7, 7, 
        7, 7, 7, 7, 7, 7, 7, 7, 
        7, 7, 7, 7, 7, 5, 7, 7, 
        7, 7, 7, 7, 7, 7, 7, 7, 
        7, 7, 7, 7, 7, 8, 8, 8, 
        8, 8, 8, 8, 8, 8, 8, 7, 
        7, 7, 7, 7, 7, 7, 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, 
        7, 7, 7, 7, 8, 7, 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, 
        7, 9, 9, 9, 9, 9, 9, 9, 
        9, 9, 9, 7, 7, 7, 7, 7, 
        7, 7, 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, 7, 7, 7, 7, 
        9, 7, 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, 7, 11, 10, 10, 
        10, 10, 10, 10, 10, 10, 10, 10, 
        10, 10, 10, 10, 10, 10, 10, 10, 
        10, 10, 10, 10, 10, 10, 10, 10, 
        10, 10, 10, 10, 10, 10, 10, 10, 
        10, 10, 10, 12, 12, 12, 12, 12, 
        12, 12, 12, 12, 12, 10, 10, 10, 
        10, 10, 10, 10, 12, 12, 12, 12, 
        12, 12, 12, 12, 12, 12, 12, 12, 
        12, 12, 12, 12, 12, 12, 12, 12, 
        12, 12, 12, 12, 12, 12, 10, 10, 
        10, 10, 12, 10, 12, 12, 12, 12, 
        12, 12, 12, 12, 12, 12, 12, 12, 
        12, 12, 12, 12, 12, 12, 12, 12, 
        12, 12, 12, 12, 12, 12, 10, 10, 
        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, 7, 9, 0, 
        8, 8, 0, 10, 9
]

class << self
        attr_accessor :_bel_trans_actions
        private :_bel_trans_actions, :_bel_trans_actions=
end
self._bel_trans_actions = [
        0, 0, 0, 0, 0, 0, 1, 3, 
        1, 0, 6, 7, 0
]

class << self
        attr_accessor :_bel_eof_actions
        private :_bel_eof_actions, :_bel_eof_actions=
end
self._bel_eof_actions = [
        0, 0, 0, 0, 0, 0, 0, 2, 
        4, 5, 8
]

class << self
        attr_accessor :bel_start
end
self.bel_start = 1;
class << self
        attr_accessor :bel_first_final
end
self.bel_first_final = 7;
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 = 6;
class << self
        attr_accessor :bel_en_unset_ast_node
end
self.bel_en_unset_ast_node = 1;


      # end: ragel
          end

Public Instance Methods

each() { |ast_node| ... } click to toggle source
# File lib/bel_parser/parsers/bel_script/unset.rb, line 563
          def each
            @buffers    = {}
            @incomplete = {}
            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 1 then
                begin

    trace('IDENTIFIER start_identifier')
    @identifier_started = true
    id_start = p;
                end
        when 7 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 3 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 6 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
        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 8 then
                begin

    trace('IDENTIFIER yield_identifier')
    yield @buffers[:ident]
                end
        when 5 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 2 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('UNSET add_name')
    key = @buffers.delete(:ident)
    @buffers[:unset_name] = key
                end
                begin

    trace('UNSET unset_end')
    name = @buffers.delete(:unset_name)
    unless name.nil?
      unset_node = unset(name, complete: name.complete)
    else
      unset_node = unset(complete: false)
    end
    @buffers[:unset] = unset_node
                end
                begin

    trace('UNSET yield_unset')
    yield @buffers[:unset]
                end
        when 4 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('UNSET add_name')
    key = @buffers.delete(:ident)
    @buffers[:unset_name] = key
                end
                begin

    trace('UNSET unset_end')
    name = @buffers.delete(:unset_name)
    unless name.nil?
      unset_node = unset(name, complete: name.complete)
    else
      unset_node = unset(complete: false)
    end
    @buffers[:unset] = unset_node
                end
                begin

    trace('UNSET yield_unset')
    yield @buffers[:unset]
                end
          end
        end

        end
        if _goto_level <= _out
                break
        end
end
        end

      # end: ragel
          end