Turn on CSS parse caching
Turn on CSS parse caching
Turn on CSS parse caching
Get the css selector in string
from the cache
# File lib/nokogiri/css/parser_extras.rb, line 17 def [] string return unless @cache_on @mutex.synchronize { @cache[string] } end
Set the css selector in string
in the cache to
value
# File lib/nokogiri/css/parser_extras.rb, line 23 def []= string, value return value unless @cache_on @mutex.synchronize { @cache[string] = value } end
Clear the cache
# File lib/nokogiri/css/parser_extras.rb, line 29 def clear_cache @mutex.synchronize { @cache = {} } end
Create a new CSS parser with respect to
namespaces
# File lib/nokogiri/css/parser_extras.rb, line 54 def initialize namespaces = {} @tokenizer = Tokenizer.new @namespaces = namespaces super() end
Parse this CSS selector in selector
.
Returns an AST.
# File lib/nokogiri/css/parser_extras.rb, line 43 def parse selector @warned ||= false unless @warned $stderr.puts('Nokogiri::CSS::Parser.parse is deprecated, call Nokogiri::CSS.parse(), this will be removed August 1st or version 1.4.0 (whichever is first)') @warned = true end new.parse selector end
Execute block
without cache
# File lib/nokogiri/css/parser_extras.rb, line 34 def without_cache &block tmp = @cache_on @cache_on = false block.call @cache_on = tmp end
reduce 0 omitted
# File lib/nokogiri/css/parser.rb, line 293 def _reduce_1(val, _values, result) result = [val.first, val.last].flatten result end
# File lib/nokogiri/css/parser.rb, line 344 def _reduce_10(val, _values, result) result = Node.new(:CONDITIONAL_SELECTOR, [ val.first, Node.new(:COMBINATOR, [val[1], val.last]) ] ) result end
# File lib/nokogiri/css/parser.rb, line 355 def _reduce_11(val, _values, result) result = Node.new(:CONDITIONAL_SELECTOR, val) result end
reduce 12 omitted
# File lib/nokogiri/css/parser.rb, line 363 def _reduce_13(val, _values, result) result = Node.new(:CONDITIONAL_SELECTOR, val) result end
# File lib/nokogiri/css/parser.rb, line 369 def _reduce_14(val, _values, result) result = Node.new(:CONDITIONAL_SELECTOR, val) result end
# File lib/nokogiri/css/parser.rb, line 375 def _reduce_15(val, _values, result) result = Node.new(:CONDITIONAL_SELECTOR, [ Node.new(:ELEMENT_NAME, ['*']), Node.new(:COMBINATOR, val) ] ) result end
# File lib/nokogiri/css/parser.rb, line 386 def _reduce_16(val, _values, result) result = Node.new(:CONDITIONAL_SELECTOR, [Node.new(:ELEMENT_NAME, ['*']), val.first] ) result end
# File lib/nokogiri/css/parser.rb, line 394 def _reduce_17(val, _values, result) result = Node.new(val[1], [val.first, val.last]) result end
reduce 18 omitted
# File lib/nokogiri/css/parser.rb, line 402 def _reduce_19(val, _values, result) result = Node.new(:CLASS_CONDITION, [val[1]]) result end
# File lib/nokogiri/css/parser.rb, line 299 def _reduce_2(val, _values, result) result = val.flatten result end
reduce 20 omitted
# File lib/nokogiri/css/parser.rb, line 409 def _reduce_21(val, _values, result) result = Node.new(:ELEMENT_NAME, val) result end
# File lib/nokogiri/css/parser.rb, line 414 def _reduce_22(val, _values, result) result = Node.new(:ELEMENT_NAME, [[val.first, val.last].compact.join(':')] ) result end
# File lib/nokogiri/css/parser.rb, line 422 def _reduce_23(val, _values, result) name = @namespaces.key?('xmlns') ? "xmlns:#{val.first}" : val.first result = Node.new(:ELEMENT_NAME, [name]) result end
# File lib/nokogiri/css/parser.rb, line 429 def _reduce_24(val, _values, result) result = val[0] result end
reduce 25 omitted
# File lib/nokogiri/css/parser.rb, line 436 def _reduce_26(val, _values, result) result = Node.new(:ATTRIBUTE_CONDITION, [val[1]] + (val[2] || []) ) result end
# File lib/nokogiri/css/parser.rb, line 444 def _reduce_27(val, _values, result) result = Node.new(:ATTRIBUTE_CONDITION, [val[1]] + (val[2] || []) ) result end
# File lib/nokogiri/css/parser.rb, line 452 def _reduce_28(val, _values, result) # Non standard, but hpricot supports it. result = Node.new(:PSEUDO_CLASS, [Node.new(:FUNCTION, ['nth-child(', val[1]])] ) result end
# File lib/nokogiri/css/parser.rb, line 461 def _reduce_29(val, _values, result) result = Node.new(:FUNCTION, [val.first.strip]) result end
# File lib/nokogiri/css/parser.rb, line 304 def _reduce_3(val, _values, result) result = :DIRECT_ADJACENT_SELECTOR result end
# File lib/nokogiri/css/parser.rb, line 467 def _reduce_30(val, _values, result) result = Node.new(:FUNCTION, [val.first.strip, val[1]].flatten) result end
# File lib/nokogiri/css/parser.rb, line 473 def _reduce_31(val, _values, result) result = Node.new(:FUNCTION, [val.first.strip, val[1]].flatten) result end
# File lib/nokogiri/css/parser.rb, line 479 def _reduce_32(val, _values, result) result = Node.new(:FUNCTION, [val.first.strip, val[1]].flatten) result end
# File lib/nokogiri/css/parser.rb, line 485 def _reduce_33(val, _values, result) result = Node.new(:FUNCTION, [val.first.strip, val[1]].flatten) result end
# File lib/nokogiri/css/parser.rb, line 491 def _reduce_34(val, _values, result) result = [val.first, val.last] result end
# File lib/nokogiri/css/parser.rb, line 496 def _reduce_35(val, _values, result) result = [val.first, val.last] result end
# File lib/nokogiri/css/parser.rb, line 501 def _reduce_36(val, _values, result) result = [val.first, val.last] result end
reduce 38 omitted
# File lib/nokogiri/css/parser.rb, line 510 def _reduce_39(val, _values, result) if val[0] == 'even' val = ["2","n","+","0"] result = Node.new(:AN_PLUS_B, val) elsif val[0] == 'odd' val = ["2","n","+","1"] result = Node.new(:AN_PLUS_B, val) else # This is not CSS standard. It allows us to support this: # assert_xpath("//a[foo(., @href)]", @parser.parse('a:foo(@href)')) # assert_xpath("//a[foo(., @a, b)]", @parser.parse('a:foo(@a, b)')) # assert_xpath("//a[foo(., a, 10)]", @parser.parse('a:foo(a, 10)')) result = val end result end
# File lib/nokogiri/css/parser.rb, line 309 def _reduce_4(val, _values, result) result = :CHILD_SELECTOR result end
# File lib/nokogiri/css/parser.rb, line 528 def _reduce_40(val, _values, result) if val[1] == 'n' result = Node.new(:AN_PLUS_B, val) else raise Racc::ParseError, "parse error on IDENT '#{val[1]}'" end result end
# File lib/nokogiri/css/parser.rb, line 538 def _reduce_41(val, _values, result) # n+3, -n+3 if val[0] == 'n' val.unshift("1") result = Node.new(:AN_PLUS_B, val) elsif val[0] == '-n' val[0] = 'n' val.unshift("-1") result = Node.new(:AN_PLUS_B, val) else raise Racc::ParseError, "parse error on IDENT '#{val[1]}'" end result end
# File lib/nokogiri/css/parser.rb, line 554 def _reduce_42(val, _values, result) if val[1] == 'n' val << "+" val << "0" result = Node.new(:AN_PLUS_B, val) else raise Racc::ParseError, "parse error on IDENT '#{val[1]}'" end result end
# File lib/nokogiri/css/parser.rb, line 566 def _reduce_43(val, _values, result) result = Node.new(:PSEUDO_CLASS, [val[1]]) result end
# File lib/nokogiri/css/parser.rb, line 572 def _reduce_44(val, _values, result) result = Node.new(:PSEUDO_CLASS, [val[1]]) result end
reduce 46 omitted
# File lib/nokogiri/css/parser.rb, line 581 def _reduce_47(val, _values, result) result = Node.new(:COMBINATOR, val) result end
# File lib/nokogiri/css/parser.rb, line 587 def _reduce_48(val, _values, result) result = Node.new(:COMBINATOR, val) result end
# File lib/nokogiri/css/parser.rb, line 593 def _reduce_49(val, _values, result) result = Node.new(:COMBINATOR, val) result end
# File lib/nokogiri/css/parser.rb, line 314 def _reduce_5(val, _values, result) result = :PRECEDING_SELECTOR result end
# File lib/nokogiri/css/parser.rb, line 599 def _reduce_50(val, _values, result) result = Node.new(:COMBINATOR, val) result end
reduce 54 omitted
# File lib/nokogiri/css/parser.rb, line 613 def _reduce_55(val, _values, result) result = Node.new(:ID, val) result end
# File lib/nokogiri/css/parser.rb, line 618 def _reduce_56(val, _values, result) result = [val.first, val[1]] result end
# File lib/nokogiri/css/parser.rb, line 623 def _reduce_57(val, _values, result) result = [val.first, val[1]] result end
reduce 58 omitted
# File lib/nokogiri/css/parser.rb, line 630 def _reduce_59(val, _values, result) result = :equal result end
# File lib/nokogiri/css/parser.rb, line 319 def _reduce_6(val, _values, result) result = :DESCENDANT_SELECTOR result end
# File lib/nokogiri/css/parser.rb, line 635 def _reduce_60(val, _values, result) result = :prefix_match result end
# File lib/nokogiri/css/parser.rb, line 640 def _reduce_61(val, _values, result) result = :suffix_match result end
# File lib/nokogiri/css/parser.rb, line 645 def _reduce_62(val, _values, result) result = :substring_match result end
# File lib/nokogiri/css/parser.rb, line 650 def _reduce_63(val, _values, result) result = :not_equal result end
# File lib/nokogiri/css/parser.rb, line 655 def _reduce_64(val, _values, result) result = :includes result end
# File lib/nokogiri/css/parser.rb, line 660 def _reduce_65(val, _values, result) result = :dash_match result end
# File lib/nokogiri/css/parser.rb, line 665 def _reduce_66(val, _values, result) result = Node.new(:NOT, [val[1]]) result end
# File lib/nokogiri/css/parser.rb, line 324 def _reduce_7(val, _values, result) result = :DESCENDANT_SELECTOR result end
# File lib/nokogiri/css/parser.rb, line 329 def _reduce_8(val, _values, result) result = :CHILD_SELECTOR result end
# File lib/nokogiri/css/parser.rb, line 334 def _reduce_9(val, _values, result) result = if val[1].nil? val.first else Node.new(:CONDITIONAL_SELECTOR, [val.first, val[1]]) end result end
reduce 69 omitted
# File lib/nokogiri/css/parser.rb, line 677 def _reduce_none(val, _values, result) val[0] end
# File lib/nokogiri/css/parser_extras.rb, line 65 def next_token @tokenizer.next_token end
On CSS parser error, raise an exception
# File lib/nokogiri/css/parser_extras.rb, line 85 def on_error error_token_id, error_value, value_stack after = value_stack.compact.last raise SyntaxError.new("unexpected '#{error_value}' after '#{after}'") end
# File lib/nokogiri/css/parser_extras.rb, line 60 def parse string @tokenizer.scan_setup string do_parse end
Get the xpath for string
using options
# File lib/nokogiri/css/parser_extras.rb, line 70 def xpath_for string, options={} key = "#{string}#{options[:ns]}#{options[:prefix]}" v = self.class[key] return v if v args = [ options[:prefix] || '//', options[:visitor] || XPathVisitor.new ] self.class[key] = parse(string).map { |ast| ast.to_xpath(*args) } end