lib/nokogiri/css/generated_tokenizer.rb



#--
# DO NOT MODIFY!!!!
# This file is automatically generated by rex 1.0.3
# from lexical definition file "lib/nokogiri/css/tokenizer.rex".
#++

module Nokogiri
module CSS
class GeneratedTokenizer < GeneratedParser
  require 'strscan'

  class ScanError < StandardError ; end

  attr_reader :lineno
  attr_reader :filename

  def scan_setup ; end

  def action &block
    yield
  end

  def scan_str( str )
    scan_evaluate  str
    do_parse
  end

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

  def scan_file( filename )
    load_file  filename
    do_parse
  end

  def next_token
    @rex_tokens.shift
  end

  def scan_evaluate( str )
    scan_setup
    @rex_tokens = []
    @lineno  =  1
    ss = StringScanner.new(str)
    state = nil
    until ss.eos?
      text = ss.peek(1)
      @lineno  +=  1  if text == "\n"
      case state
      when nil
        case
        when (text = ss.scan(/[-@]?([_A-Za-z]|[^\0-\177]|\\[0-9A-Fa-f]{1,6}(\r\n|[\s\n\r\t\f])?|\\[^\n\r\f0-9A-Fa-f])([_A-Za-z0-9-]|[^\0-\177]|\\[0-9A-Fa-f]{1,6}(\r\n|[\s\n\r\t\f])?|\\[^\n\r\f0-9A-Fa-f])*\(\s*/))
           @rex_tokens.push action { [:FUNCTION, text] }

        when (text = ss.scan(/[-@]?([_A-Za-z]|[^\0-\177]|\\[0-9A-Fa-f]{1,6}(\r\n|[\s\n\r\t\f])?|\\[^\n\r\f0-9A-Fa-f])([_A-Za-z0-9-]|[^\0-\177]|\\[0-9A-Fa-f]{1,6}(\r\n|[\s\n\r\t\f])?|\\[^\n\r\f0-9A-Fa-f])*/))
           @rex_tokens.push action { [:IDENT, text] }

        when (text = ss.scan(/\#([_A-Za-z0-9-]|[^\0-\177]|\\[0-9A-Fa-f]{1,6}(\r\n|[\s\n\r\t\f])?|\\[^\n\r\f0-9A-Fa-f])+/))
           @rex_tokens.push action { [:HASH, text] }

        when (text = ss.scan(/[\s\r\n\f]*~=[\s\r\n\f]*/))
           @rex_tokens.push action { [:INCLUDES, text] }

        when (text = ss.scan(/[\s\r\n\f]*\|=[\s\r\n\f]*/))
           @rex_tokens.push action { [:DASHMATCH, text] }

        when (text = ss.scan(/[\s\r\n\f]*\^=[\s\r\n\f]*/))
           @rex_tokens.push action { [:PREFIXMATCH, text] }

        when (text = ss.scan(/[\s\r\n\f]*\$=[\s\r\n\f]*/))
           @rex_tokens.push action { [:SUFFIXMATCH, text] }

        when (text = ss.scan(/[\s\r\n\f]*\*=[\s\r\n\f]*/))
           @rex_tokens.push action { [:SUBSTRINGMATCH, text] }

        when (text = ss.scan(/[\s\r\n\f]*!=[\s\r\n\f]*/))
           @rex_tokens.push action { [:NOT_EQUAL, text] }

        when (text = ss.scan(/[\s\r\n\f]*=[\s\r\n\f]*/))
           @rex_tokens.push action { [:EQUAL, text] }

        when (text = ss.scan(/[\s\r\n\f]*\)/))
           @rex_tokens.push action { [:RPAREN, text] }

        when (text = ss.scan(/[\s\r\n\f]*\[[\s\r\n\f]*/))
           @rex_tokens.push action { [:LSQUARE, text] }

        when (text = ss.scan(/[\s\r\n\f]*\]/))
           @rex_tokens.push action { [:RSQUARE, text] }

        when (text = ss.scan(/[\s\r\n\f]*\+[\s\r\n\f]*/))
           @rex_tokens.push action { [:PLUS, text] }

        when (text = ss.scan(/[\s\r\n\f]*>[\s\r\n\f]*/))
           @rex_tokens.push action { [:GREATER, text] }

        when (text = ss.scan(/[\s\r\n\f]*,[\s\r\n\f]*/))
           @rex_tokens.push action { [:COMMA, text] }

        when (text = ss.scan(/[\s\r\n\f]*~[\s\r\n\f]*/))
           @rex_tokens.push action { [:TILDE, text] }

        when (text = ss.scan(/\:not\([\s\r\n\f]*/))
           @rex_tokens.push action { [:NOT, text] }

        when (text = ss.scan(/-?([0-9]+|[0-9]*\.[0-9]+)/))
           @rex_tokens.push action { [:NUMBER, text] }

        when (text = ss.scan(/[\s\r\n\f]*\/\/[\s\r\n\f]*/))
           @rex_tokens.push action { [:DOUBLESLASH, text] }

        when (text = ss.scan(/[\s\r\n\f]*\/[\s\r\n\f]*/))
           @rex_tokens.push action { [:SLASH, text] }

        when (text = ss.scan(/U\+[0-9a-f?]{1,6}(-[0-9a-f]{1,6})?/))
           @rex_tokens.push action {[:UNICODE_RANGE, text] }

        when (text = ss.scan(/[\s\t\r\n\f]+/))
           @rex_tokens.push action { [:S, text] }

        when (text = ss.scan(/"([^\n\r\f"]|\n|\r\n|\r|\f|[^\0-\177]|\\[0-9A-Fa-f]{1,6}(\r\n|[\s\n\r\t\f])?|\\[^\n\r\f0-9A-Fa-f])*"|'([^\n\r\f']|\n|\r\n|\r|\f|[^\0-\177]|\\[0-9A-Fa-f]{1,6}(\r\n|[\s\n\r\t\f])?|\\[^\n\r\f0-9A-Fa-f])*'/))
           @rex_tokens.push action { [:STRING, text] }

        when (text = ss.scan(/./))
           @rex_tokens.push action { [text, 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
    end  # until ss
  end  # def scan_evaluate

end # class
end
end