123456789_123456789_123456789_123456789_123456789_

Class: Nokogiri::CSS::Tokenizer

Do not use. This class is for internal use only.
Relationships & Source Files
Namespace Children
Exceptions:
Inherits: Object
Defined in: lib/nokogiri/css/tokenizer.rb

Instance Attribute Summary

Instance Method Summary

Instance Attribute Details

#filename (readonly)

[ GitHub ]

  
# File 'lib/nokogiri/css/tokenizer.rb', line 17

attr_reader   :filename

#lineno (readonly)

[ GitHub ]

  
# File 'lib/nokogiri/css/tokenizer.rb', line 16

attr_reader   :lineno

#state (rw)

[ GitHub ]

  
# File 'lib/nokogiri/css/tokenizer.rb', line 18

attr_accessor :state

Instance Method Details

#_next_token

[ GitHub ]

  
# File 'lib/nokogiri/css/tokenizer.rb', line 57

def _next_token
  text = @ss.peek(1)
  @lineno  +=  1  if text == "\n"
  token = case @state
    when nil
  case
          when (text = @ss.scan(/has\([\s]*/))
             action { [:HAS, text] }

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

          when (text = @ss.scan(/[\s]+/))
             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\f0-9A-Fa-f])*(?<!\\)(?:\\{2})*"|'([^\n\r\f']|\n|\r\n|\r|\f|[^\0-\177]|\\[0-9A-Fa-f]{1,6}(\r\n|[\s])?|\\[^\n\r\f0-9A-Fa-f])*(?<!\\)(?:\\{2})*'/))
             action { [:STRING, text] }

          when (text = @ss.scan(/./))
             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
  token
end

#action

[ GitHub ]

  
# File 'lib/nokogiri/css/tokenizer.rb', line 26

def action
  yield
end

#load_file(filename)

[ GitHub ]

  
# File 'lib/nokogiri/css/tokenizer.rb', line 36

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

#next_token

[ GitHub ]

  
# File 'lib/nokogiri/css/tokenizer.rb', line 49

def next_token
  return if @ss.eos?

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

#scan(str)

Alias for #scan_str.

[ GitHub ]

  
# File 'lib/nokogiri/css/tokenizer.rb', line 34

alias :scan :scan_str

#scan_file(filename)

[ GitHub ]

  
# File 'lib/nokogiri/css/tokenizer.rb', line 43

def scan_file( filename )
  load_file(filename)
  do_parse
end

#scan_setup(str)

[ GitHub ]

  
# File 'lib/nokogiri/css/tokenizer.rb', line 20

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

#scan_str(str) Also known as: #scan

[ GitHub ]

  
# File 'lib/nokogiri/css/tokenizer.rb', line 30

def scan_str(str)
  scan_setup(str)
  do_parse
end