class Gem::RequestSet::Lockfile::Tokenizer

常量

EOF
Token

公共类方法

from_file(file) 点击以切换源代码
# File rubygems/request_set/lockfile/tokenizer.rb, line 10
def self.from_file(file)
  new File.read(file), file
end
new(input, filename = nil, line = 0, pos = 0) 点击以切换源代码
# File rubygems/request_set/lockfile/tokenizer.rb, line 14
def initialize(input, filename = nil, line = 0, pos = 0)
  @line     = line
  @line_pos = pos
  @tokens   = []
  @filename = filename
  tokenize input
end

公共实例方法

empty?() 点击以切换源代码
# File rubygems/request_set/lockfile/tokenizer.rb, line 42
def empty?
  @tokens.empty?
end
make_parser(set, platforms) 点击以切换源代码
# File rubygems/request_set/lockfile/tokenizer.rb, line 22
def make_parser(set, platforms)
  Gem::RequestSet::Lockfile::Parser.new self, set, platforms, @filename
end
next_token() 点击以切换源代码
# File rubygems/request_set/lockfile/tokenizer.rb, line 50
def next_token
  @tokens.shift
end
别名: shift
peek() 点击以切换源代码
# File rubygems/request_set/lockfile/tokenizer.rb, line 55
def peek
  @tokens.first || EOF
end
shift()
别名: next_token
skip(type) 点击以切换源代码
# File rubygems/request_set/lockfile/tokenizer.rb, line 30
def skip(type)
  @tokens.shift while !@tokens.empty? && peek.type == type
end
to_a() 点击以切换源代码
# File rubygems/request_set/lockfile/tokenizer.rb, line 26
def to_a
  @tokens.map {|token| [token.type, token.value, token.column, token.line] }
end
unshift(token) 点击以切换源代码
# File rubygems/request_set/lockfile/tokenizer.rb, line 46
def unshift(token)
  @tokens.unshift token
end

私有实例方法

tokenize(input) 点击以切换源代码
# File rubygems/request_set/lockfile/tokenizer.rb, line 61
def tokenize(input)
  require "strscan"
  s = StringScanner.new input

  until s.eos? do
    pos = s.pos

    pos = s.pos if leading_whitespace = s.scan(/ +/)

    if s.scan(/[<|=>]{7}/)
      message = "your #{@filename} contains merge conflict markers"
      column, line = token_pos pos

      raise Gem::RequestSet::Lockfile::ParseError.new message, column, line, @filename
    end

    @tokens <<
      if s.scan(/\r?\n/)

        token = Token.new(:newline, nil, *token_pos(pos))
        @line_pos = s.pos
        @line += 1
        token
      elsif s.scan(/[A-Z]+/)

        if leading_whitespace
          text = s.matched
          text += s.scan(/[^\s)]*/).to_s # in case of no match
          Token.new(:text, text, *token_pos(pos))
        else
          Token.new(:section, s.matched, *token_pos(pos))
        end
      elsif s.scan(/([a-z]+):\s/)

        s.pos -= 1 # rewind for possible newline
        Token.new(:entry, s[1], *token_pos(pos))
      elsif s.scan(/\(/)

        Token.new(:l_paren, nil, *token_pos(pos))
      elsif s.scan(/\)/)

        Token.new(:r_paren, nil, *token_pos(pos))
      elsif s.scan(/<=|>=|=|~>|<|>|!=/)

        Token.new(:requirement, s.matched, *token_pos(pos))
      elsif s.scan(/,/)

        Token.new(:comma, nil, *token_pos(pos))
      elsif s.scan(/!/)

        Token.new(:bang, nil, *token_pos(pos))
      elsif s.scan(/[^\s),!]*/)

        Token.new(:text, s.matched, *token_pos(pos))
      else
        raise "BUG: can't create token for: #{s.string[s.pos..-1].inspect}"
      end
  end

  @tokens
end