HEX

Warning: set_time_limit() [function.set-time-limit]: Cannot set time limit - prohibited by configuration in /home/u547966/brikov.ru/www/wp-content/plugins/admin-menu-editor/menu-editor.php on line 745
Server: Apache
System: Linux 4.19.0-0.bpo.9-amd64 x86_64 at red40
User: u547966 (5490)
PHP: 5.3.29-mh2
Disabled: syslog, dl, popen, proc_open, proc_nice, proc_get_status, proc_close, proc_terminate, posix_mkfifo, chown, chgrp, accelerator_reset, opcache_reset, accelerator_get_status, opcache_get_status, pcntl_alarm, pcntl_fork, pcntl_waitpid, pcntl_wait, pcntl_wifexited, pcntl_wifstopped, pcntl_wifsignaled, pcntl_wifcontinued, pcntl_wexitstatus, pcntl_wtermsig, pcntl_wstopsig, pcntl_signal, pcntl_signal_dispatch, pcntl_get_last_error, pcntl_strerror, pcntl_sigprocmask, pcntl_sigwaitinfo, pcntl_sigtimedwait, pcntl_exec, pcntl_getpriority, pcntl_setpriority
Upload Files
File: //proc/self/root/var/cache/puppet/lib/puppetdb/lexer.rb
#--
# DO NOT MODIFY!!!!
# This file is automatically generated by rex 1.0.5
# from lexical definition file "lib/puppetdb/lexer.rex".
#++

require 'racc/parser'
# vim: syntax=ruby

require 'yaml'
require 'puppetdb'

class PuppetDB::Lexer < Racc::Parser
  require 'strscan'

  class ScanError < StandardError ; end

  attr_reader   :lineno
  attr_reader   :filename
  attr_accessor :state

  def scan_setup(str)
    @ss = StringScanner.new(str)
    @lineno =  1
    @state  = nil
  end

  def action
    yield
  end

  def scan_str(str)
    scan_setup(str)
    do_parse
  end
  alias :scan :scan_str

  def load_file( filename )
    @filename = filename
    open(filename, "r") do |f|
      scan_setup(f.read)
    end
  end

  def scan_file( filename )
    load_file(filename)
    do_parse
  end


  def next_token
    return if @ss.eos?
    
    # skips empty actions
    until token = _next_token or @ss.eos?; end
    token
  end

  def _next_token
    text = @ss.peek(1)
    @lineno  +=  1  if text == "\n"
    token = case @state
    when nil
      case
      when (text = @ss.scan(/\s/))
        ;

      when (text = @ss.scan(/\(/))
         action { [:LPAREN, text] }

      when (text = @ss.scan(/\)/))
         action { [:RPAREN, text] }

      when (text = @ss.scan(/\[/))
         action { [:LBRACK, text] }

      when (text = @ss.scan(/\]/))
         action { [:RBRACK, text] }

      when (text = @ss.scan(/\{/))
         action { [:LBRACE, text] }

      when (text = @ss.scan(/\}/))
         action { [:RBRACE, text] }

      when (text = @ss.scan(/=/))
         action { [:EQUALS, text] }

      when (text = @ss.scan(/\!=/))
         action { [:NOTEQUALS, text] }

      when (text = @ss.scan(/~/))
         action { [:MATCH, text] }

      when (text = @ss.scan(/\!~/))
         action { [:NOTMATCH, text] }

      when (text = @ss.scan(/<=/))
         action { [:LESSTHANEQ, text] }

      when (text = @ss.scan(/</))
         action { [:LESSTHAN, text] }

      when (text = @ss.scan(/>=/))
         action { [:GREATERTHANEQ, text] }

      when (text = @ss.scan(/>/))
         action { [:GREATERTHAN, text] }

      when (text = @ss.scan(/\*/))
         action { [:ASTERISK, text] }

      when (text = @ss.scan(/\#/))
         action { [:HASH, text] }

      when (text = @ss.scan(/\./))
         action { [:DOT, text] }

      when (text = @ss.scan(/not(?![\w_:])/))
         action { [:NOT, text] }

      when (text = @ss.scan(/and(?![\w_:])/))
         action { [:AND, text] }

      when (text = @ss.scan(/or(?![\w_:])/))
         action { [:OR, text] }

      when (text = @ss.scan(/true(?![\w_:])/))
         action { [:BOOLEAN, true]}

      when (text = @ss.scan(/false(?![\w_:])/))
         action { [:BOOLEAN, false]}

      when (text = @ss.scan(/-?\d+/))
         action { [:NUMBER, text.to_i] }

      when (text = @ss.scan(/\"(\\.|[^\\"])*\"/))
         action { [:STRING, YAML.load(text)] }

      when (text = @ss.scan(/\'(\\.|[^\\'])*\'/))
         action { [:STRING, YAML.load(text)] }

      when (text = @ss.scan(/[\w_:]+/))
         action { [:STRING, text] }

      when (text = @ss.scan(/@@/))
         action { [:EXPORTED, text] }

      when (text = @ss.scan(/@/))
         action { [:AT, text] }

      else
        text = @ss.string[@ss.pos .. -1]
        raise  ScanError, "can not match: '" + text + "'"
      end  # if

    else
      raise  ScanError, "undefined state: '" + state.to_s + "'"
    end  # case state
    token
  end  # def _next_token

end # class