#
# DO NOT MODIFY!!!!
# This file is automatically generated by Racc 1.4.6
# from Racc grammer file "".
#
require 'racc/parser.rb'
module Nokogiri
module CSS
class GeneratedParser < Racc::Parser
##### State transition tables begin ###
racc_action_table = [
4, 56, 27, 22, 12, 24, 57, 4, 65, 1,
41, 12, 75, 57, 4, 23, 1, 82, 12, 19,
93, 92, 5, 1, 9, 10, 19, 13, 16, 5,
12, 9, 10, 19, 13, 16, 5, 5, 9, 10,
4, 13, 16, 16, 12, 41, 64, 4, 5, 1,
60, 10, 12, 59, 16, 59, 28, 1, 29, 19,
12, 12, 5, 62, 9, 10, 19, 13, 16, 12,
5, 9, 83, 10, 12, 13, 16, 84, 5, 5,
63, 10, 10, 12, 16, 16, 58, 5, 61, 62,
10, 4, 5, 16, 87, 10, 27, 53, 16, 54,
49, 5, 88, 41, 10, 68, 70, 16, 27, 53,
19, 54, 44, 91, 21, 9, 69, 71, 72, 94,
74, 68, 70, -23, 66, 33, 35, 37, 27, 53,
96, 54, 69, 71, 72, 32, 74, 34, 36, 97,
66, 27, 53, nil, 54 ]
racc_action_check = [
0, 20, 4, 4, 0, 4, 43, 9, 27, 0,
39, 9, 29, 20, 31, 4, 9, 43, 31, 0,
73, 73, 0, 31, 0, 0, 9, 0, 0, 9,
7, 9, 9, 31, 9, 9, 31, 14, 31, 31,
57, 31, 31, 14, 57, 7, 26, 5, 7, 57,
22, 7, 41, 53, 7, 22, 5, 41, 5, 57,
8, 79, 57, 54, 57, 57, 5, 57, 57, 18,
41, 5, 55, 41, 17, 41, 41, 56, 8, 79,
25, 8, 79, 15, 8, 79, 21, 18, 24, 24,
18, 16, 17, 18, 60, 17, 59, 59, 17, 59,
16, 15, 61, 11, 15, 30, 30, 15, 19, 19,
16, 19, 10, 67, 2, 16, 30, 30, 30, 76,
30, 28, 28, 1, 30, 6, 6, 6, 62, 62,
81, 62, 28, 28, 28, 6, 28, 6, 6, 88,
28, 65, 65, nil, 65 ]
racc_action_pointer = [
-2, 95, 86, nil, -8, 45, 118, 24, 54, 5,
101, 82, nil, nil, 13, 77, 89, 68, 63, 98,
1, 75, 43, nil, 77, 57, 23, -4, 118, -13,
102, 12, nil, nil, nil, nil, nil, nil, nil, -11,
nil, 46, nil, -6, nil, nil, nil, nil, nil, nil,
nil, nil, nil, 41, 51, 49, 77, 38, nil, 86,
81, 95, 118, nil, nil, 131, nil, 88, nil, nil,
nil, nil, nil, 10, nil, nil, 94, nil, nil, 55,
nil, 107, nil, nil, nil, nil, nil, nil, 126, nil,
nil, nil, nil, nil, nil, nil, nil, nil ]
racc_action_default = [
-24, -21, -69, -2, -69, -69, -18, -45, -50, -24,
-69, -16, -54, -22, -12, -53, -69, -52, -51, -69,
-69, -69, -38, -28, -36, -69, -69, -37, -57, -69,
-57, -24, -5, -3, -8, -4, -7, -6, -9, -44,
-11, -24, -46, -69, -19, -15, -13, -14, -49, -43,
-42, -48, -47, -38, -36, -69, -69, -24, -20, -69,
-69, -41, -69, -29, -30, -69, -58, -69, -63, -59,
-64, -60, -61, -69, -62, -27, -69, -17, -10, -66,
-68, -69, -32, -31, 98, -1, -35, -40, -69, -33,
-34, -25, -55, -56, -26, -67, -65, -39 ]
racc_goto_table = [
39, 42, 25, 40, 77, 30, 20, 45, 48, 79,
51, 52, 67, 46, 76, 43, 50, 55, 47, 38,
31, 26, 81, nil, nil, nil, nil, nil, nil, nil,
85, nil, nil, nil, 80, 78, nil, nil, nil, nil,
nil, nil, nil, nil, nil, nil, nil, nil, nil, nil,
nil, nil, nil, nil, nil, nil, nil, 86, nil, nil,
89, nil, nil, 90, nil, nil, nil, nil, nil, nil,
nil, nil, 95 ]
racc_goto_check = [
7, 7, 15, 8, 2, 9, 1, 8, 7, 5,
7, 7, 14, 10, 14, 1, 9, 15, 11, 6,
3, 16, 19, nil, nil, nil, nil, nil, nil, nil,
2, nil, nil, nil, 7, 8, nil, nil, nil, nil,
nil, nil, nil, nil, nil, nil, nil, nil, nil, nil,
nil, nil, nil, nil, nil, nil, nil, 15, nil, nil,
15, nil, nil, 15, nil, nil, nil, nil, nil, nil,
nil, nil, 7 ]
racc_goto_pointer = [
nil, 6, -27, 14, nil, -32, 12, -7, -4, 0,
-1, 4, nil, nil, -16, -2, 17, nil, nil, -19 ]
racc_goto_default = [
nil, nil, 3, nil, 6, 7, nil, 11, nil, 14,
15, 17, 18, 2, nil, nil, nil, 8, 73, nil ]
racc_reduce_table = [
0, 0, :racc_error,
3, 32, :_reduce_1,
1, 32, :_reduce_2,
1, 34, :_reduce_3,
1, 34, :_reduce_4,
1, 34, :_reduce_5,
1, 34, :_reduce_6,
1, 34, :_reduce_7,
1, 34, :_reduce_8,
2, 35, :_reduce_9,
3, 35, :_reduce_10,
2, 35, :_reduce_11,
1, 35, :_reduce_none,
2, 35, :_reduce_13,
2, 35, :_reduce_14,
2, 35, :_reduce_15,
1, 35, :_reduce_16,
3, 33, :_reduce_17,
1, 33, :_reduce_none,
2, 43, :_reduce_19,
3, 36, :_reduce_20,
1, 36, :_reduce_21,
1, 36, :_reduce_22,
1, 44, :_reduce_23,
0, 44, :_reduce_none,
4, 42, :_reduce_25,
4, 42, :_reduce_26,
3, 42, :_reduce_27,
2, 40, :_reduce_28,
3, 40, :_reduce_29,
3, 40, :_reduce_30,
3, 40, :_reduce_31,
3, 40, :_reduce_32,
3, 46, :_reduce_33,
3, 46, :_reduce_34,
3, 46, :_reduce_35,
1, 46, :_reduce_none,
1, 46, :_reduce_none,
1, 46, :_reduce_38,
4, 47, :_reduce_39,
3, 47, :_reduce_40,
2, 47, :_reduce_41,
2, 41, :_reduce_42,
2, 41, :_reduce_43,
1, 37, :_reduce_none,
0, 37, :_reduce_none,
2, 38, :_reduce_46,
2, 38, :_reduce_47,
2, 38, :_reduce_48,
2, 38, :_reduce_49,
1, 38, :_reduce_none,
1, 38, :_reduce_none,
1, 38, :_reduce_none,
1, 38, :_reduce_none,
1, 48, :_reduce_54,
2, 45, :_reduce_55,
2, 45, :_reduce_56,
0, 45, :_reduce_none,
1, 49, :_reduce_58,
1, 49, :_reduce_59,
1, 49, :_reduce_60,
1, 49, :_reduce_61,
1, 49, :_reduce_62,
1, 49, :_reduce_63,
1, 49, :_reduce_64,
3, 39, :_reduce_65,
1, 50, :_reduce_none,
2, 50, :_reduce_none,
1, 50, :_reduce_none ]
racc_reduce_n = 69
racc_shift_n = 98
racc_token_table = {
false => 0,
:error => 1,
:FUNCTION => 2,
:INCLUDES => 3,
:DASHMATCH => 4,
:LBRACE => 5,
:HASH => 6,
:PLUS => 7,
:GREATER => 8,
:S => 9,
:STRING => 10,
:IDENT => 11,
:COMMA => 12,
:NUMBER => 13,
:PREFIXMATCH => 14,
:SUFFIXMATCH => 15,
:SUBSTRINGMATCH => 16,
:TILDE => 17,
:NOT_EQUAL => 18,
:SLASH => 19,
:DOUBLESLASH => 20,
:NOT => 21,
:EQUAL => 22,
:RPAREN => 23,
:LSQUARE => 24,
:RSQUARE => 25,
:HAS => 26,
"." => 27,
"|" => 28,
"*" => 29,
":" => 30 }
racc_nt_base = 31
racc_use_result_var = true
Racc_arg = [
racc_action_table,
racc_action_check,
racc_action_default,
racc_action_pointer,
racc_goto_table,
racc_goto_check,
racc_goto_default,
racc_goto_pointer,
racc_nt_base,
racc_reduce_table,
racc_token_table,
racc_shift_n,
racc_reduce_n,
racc_use_result_var ]
Racc_token_to_s_table = [
"$end",
"error",
"FUNCTION",
"INCLUDES",
"DASHMATCH",
"LBRACE",
"HASH",
"PLUS",
"GREATER",
"S",
"STRING",
"IDENT",
"COMMA",
"NUMBER",
"PREFIXMATCH",
"SUFFIXMATCH",
"SUBSTRINGMATCH",
"TILDE",
"NOT_EQUAL",
"SLASH",
"DOUBLESLASH",
"NOT",
"EQUAL",
"RPAREN",
"LSQUARE",
"RSQUARE",
"HAS",
"\".\"",
"\"|\"",
"\"*\"",
"\":\"",
"$start",
"selector",
"simple_selector_1toN",
"combinator",
"simple_selector",
"element_name",
"hcap_0toN",
"hcap_1toN",
"negation",
"function",
"pseudo",
"attrib",
"class",
"namespace",
"attrib_val_0or1",
"expr",
"an_plus_b",
"attribute_id",
"eql_incl_dash",
"negation_arg" ]
Racc_debug_parser = false
##### State transition tables end #####
# reduce 0 omitted
def _reduce_1(val, _values, result)
result = [val.first, val.last].flatten
result
end
def _reduce_2(val, _values, result)
result = val.flatten
result
end
def _reduce_3(val, _values, result)
result = :DIRECT_ADJACENT_SELECTOR
result
end
def _reduce_4(val, _values, result)
result = :CHILD_SELECTOR
result
end
def _reduce_5(val, _values, result)
result = :PRECEDING_SELECTOR
result
end
def _reduce_6(val, _values, result)
result = :DESCENDANT_SELECTOR
result
end
def _reduce_7(val, _values, result)
result = :DESCENDANT_SELECTOR
result
end
def _reduce_8(val, _values, result)
result = :CHILD_SELECTOR
result
end
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
def _reduce_10(val, _values, result)
result = Node.new(:CONDITIONAL_SELECTOR,
[
val.first,
Node.new(:COMBINATOR, [val[1], val.last])
]
)
result
end
def _reduce_11(val, _values, result)
result = Node.new(:CONDITIONAL_SELECTOR, val)
result
end
# reduce 12 omitted
def _reduce_13(val, _values, result)
result = Node.new(:CONDITIONAL_SELECTOR, val)
result
end
def _reduce_14(val, _values, result)
result = Node.new(:CONDITIONAL_SELECTOR, val)
result
end
def _reduce_15(val, _values, result)
result = Node.new(:CONDITIONAL_SELECTOR,
[
Node.new(:ELEMENT_NAME, ['*']),
Node.new(:COMBINATOR, val)
]
)
result
end
def _reduce_16(val, _values, result)
result = Node.new(:CONDITIONAL_SELECTOR,
[Node.new(:ELEMENT_NAME, ['*']), val.first]
)
result
end
def _reduce_17(val, _values, result)
result = Node.new(val[1], [val.first, val.last])
result
end
# reduce 18 omitted
def _reduce_19(val, _values, result)
result = Node.new(:CLASS_CONDITION, [val[1]])
result
end
def _reduce_20(val, _values, result)
result = Node.new(:ELEMENT_NAME,
[[val.first, val.last].compact.join(':')]
)
result
end
def _reduce_21(val, _values, result)
name = @namespaces.key?('xmlns') ? "xmlns:#{val.first}" : val.first
result = Node.new(:ELEMENT_NAME, [name])
result
end
def _reduce_22(val, _values, result)
result = Node.new(:ELEMENT_NAME, val)
result
end
def _reduce_23(val, _values, result)
result = val[0]
result
end
# reduce 24 omitted
def _reduce_25(val, _values, result)
result = Node.new(:ATTRIBUTE_CONDITION,
[Node.new(:ELEMENT_NAME, [val[1]])] + (val[2] || [])
)
result
end
def _reduce_26(val, _values, result)
result = Node.new(:ATTRIBUTE_CONDITION,
[val[1]] + (val[2] || [])
)
result
end
def _reduce_27(val, _values, result)
# Non standard, but hpricot supports it.
result = Node.new(:PSEUDO_CLASS,
[Node.new(:FUNCTION, ['nth-child(', val[1]])]
)
result
end
def _reduce_28(val, _values, result)
result = Node.new(:FUNCTION, [val.first.strip])
result
end
def _reduce_29(val, _values, result)
result = Node.new(:FUNCTION, [val.first.strip, val[1]].flatten)
result
end
def _reduce_30(val, _values, result)
result = Node.new(:FUNCTION, [val.first.strip, val[1]].flatten)
result
end
def _reduce_31(val, _values, result)
result = Node.new(:FUNCTION, [val.first.strip, val[1]].flatten)
result
end
def _reduce_32(val, _values, result)
result = Node.new(:FUNCTION, [val.first.strip, val[1]].flatten)
result
end
def _reduce_33(val, _values, result)
result = [val.first, val.last]
result
end
def _reduce_34(val, _values, result)
result = [val.first, val.last]
result
end
def _reduce_35(val, _values, result)
result = [val.first, val.last]
result
end
# reduce 36 omitted
# reduce 37 omitted
def _reduce_38(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
def _reduce_39(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
def _reduce_40(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
def _reduce_41(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
def _reduce_42(val, _values, result)
result = Node.new(:PSEUDO_CLASS, [val[1]])
result
end
def _reduce_43(val, _values, result)
result = Node.new(:PSEUDO_CLASS, [val[1]])
result
end
# reduce 44 omitted
# reduce 45 omitted
def _reduce_46(val, _values, result)
result = Node.new(:COMBINATOR, val)
result
end
def _reduce_47(val, _values, result)
result = Node.new(:COMBINATOR, val)
result
end
def _reduce_48(val, _values, result)
result = Node.new(:COMBINATOR, val)
result
end
def _reduce_49(val, _values, result)
result = Node.new(:COMBINATOR, val)
result
end
# reduce 50 omitted
# reduce 51 omitted
# reduce 52 omitted
# reduce 53 omitted
def _reduce_54(val, _values, result)
result = Node.new(:ID, val)
result
end
def _reduce_55(val, _values, result)
result = [val.first, val[1]]
result
end
def _reduce_56(val, _values, result)
result = [val.first, val[1]]
result
end
# reduce 57 omitted
def _reduce_58(val, _values, result)
result = :equal
result
end
def _reduce_59(val, _values, result)
result = :prefix_match
result
end
def _reduce_60(val, _values, result)
result = :suffix_match
result
end
def _reduce_61(val, _values, result)
result = :substring_match
result
end
def _reduce_62(val, _values, result)
result = :not_equal
result
end
def _reduce_63(val, _values, result)
result = :includes
result
end
def _reduce_64(val, _values, result)
result = :dash_match
result
end
def _reduce_65(val, _values, result)
result = Node.new(:NOT, [val[1]])
result
end
# reduce 66 omitted
# reduce 67 omitted
# reduce 68 omitted
def _reduce_none(val, _values, result)
val[0]
end
end # class GeneratedParser
end # module CSS
end # module Nokogiri