nokogiri 1.11.0.rc1-x86-linux → 1.11.1-x86-linux
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of nokogiri might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/Gemfile +3 -0
- data/LICENSE-DEPENDENCIES.md +1015 -947
- data/README.md +164 -92
- data/ext/nokogiri/depend +476 -357
- data/ext/nokogiri/extconf.rb +467 -326
- data/ext/nokogiri/html_document.c +79 -78
- data/ext/nokogiri/html_sax_parser_context.c +4 -2
- data/ext/nokogiri/html_sax_push_parser.c +14 -8
- data/ext/nokogiri/include/libexslt/exslt.h +102 -0
- data/ext/nokogiri/include/libexslt/exsltconfig.h +70 -0
- data/ext/nokogiri/include/libexslt/exsltexports.h +140 -0
- data/ext/nokogiri/include/libxml2/libxml/DOCBparser.h +96 -0
- data/ext/nokogiri/include/libxml2/libxml/HTMLparser.h +306 -0
- data/ext/nokogiri/include/libxml2/libxml/HTMLtree.h +147 -0
- data/ext/nokogiri/include/libxml2/libxml/SAX.h +173 -0
- data/ext/nokogiri/include/libxml2/libxml/SAX2.h +178 -0
- data/ext/nokogiri/include/libxml2/libxml/c14n.h +126 -0
- data/ext/nokogiri/include/libxml2/libxml/catalog.h +182 -0
- data/ext/nokogiri/include/libxml2/libxml/chvalid.h +230 -0
- data/ext/nokogiri/include/libxml2/libxml/debugXML.h +217 -0
- data/ext/nokogiri/include/libxml2/libxml/dict.h +79 -0
- data/ext/nokogiri/include/libxml2/libxml/encoding.h +245 -0
- data/ext/nokogiri/include/libxml2/libxml/entities.h +151 -0
- data/ext/nokogiri/include/libxml2/libxml/globals.h +508 -0
- data/ext/nokogiri/include/libxml2/libxml/hash.h +236 -0
- data/ext/nokogiri/include/libxml2/libxml/list.h +137 -0
- data/ext/nokogiri/include/libxml2/libxml/nanoftp.h +163 -0
- data/ext/nokogiri/include/libxml2/libxml/nanohttp.h +81 -0
- data/ext/nokogiri/include/libxml2/libxml/parser.h +1241 -0
- data/ext/nokogiri/include/libxml2/libxml/parserInternals.h +644 -0
- data/ext/nokogiri/include/libxml2/libxml/pattern.h +100 -0
- data/ext/nokogiri/include/libxml2/libxml/relaxng.h +217 -0
- data/ext/nokogiri/include/libxml2/libxml/schemasInternals.h +958 -0
- data/ext/nokogiri/include/libxml2/libxml/schematron.h +142 -0
- data/ext/nokogiri/include/libxml2/libxml/threads.h +89 -0
- data/ext/nokogiri/include/libxml2/libxml/tree.h +1311 -0
- data/ext/nokogiri/include/libxml2/libxml/uri.h +94 -0
- data/ext/nokogiri/include/libxml2/libxml/valid.h +458 -0
- data/ext/nokogiri/include/libxml2/libxml/xinclude.h +129 -0
- data/ext/nokogiri/include/libxml2/libxml/xlink.h +189 -0
- data/ext/nokogiri/include/libxml2/libxml/xmlIO.h +366 -0
- data/ext/nokogiri/include/libxml2/libxml/xmlautomata.h +146 -0
- data/ext/nokogiri/include/libxml2/libxml/xmlerror.h +945 -0
- data/ext/nokogiri/include/libxml2/libxml/xmlexports.h +153 -0
- data/ext/nokogiri/include/libxml2/libxml/xmlmemory.h +224 -0
- data/ext/nokogiri/include/libxml2/libxml/xmlmodule.h +57 -0
- data/ext/nokogiri/include/libxml2/libxml/xmlreader.h +428 -0
- data/ext/nokogiri/include/libxml2/libxml/xmlregexp.h +222 -0
- data/ext/nokogiri/include/libxml2/libxml/xmlsave.h +88 -0
- data/ext/nokogiri/include/libxml2/libxml/xmlschemas.h +246 -0
- data/ext/nokogiri/include/libxml2/libxml/xmlschemastypes.h +151 -0
- data/ext/nokogiri/include/libxml2/libxml/xmlstring.h +140 -0
- data/ext/nokogiri/include/libxml2/libxml/xmlunicode.h +202 -0
- data/ext/nokogiri/include/libxml2/libxml/xmlversion.h +485 -0
- data/ext/nokogiri/include/libxml2/libxml/xmlwriter.h +488 -0
- data/ext/nokogiri/include/libxml2/libxml/xpath.h +566 -0
- data/ext/nokogiri/include/libxml2/libxml/xpathInternals.h +632 -0
- data/ext/nokogiri/include/libxml2/libxml/xpointer.h +114 -0
- data/ext/nokogiri/include/libxslt/attributes.h +38 -0
- data/ext/nokogiri/include/libxslt/documents.h +93 -0
- data/ext/nokogiri/include/libxslt/extensions.h +262 -0
- data/ext/nokogiri/include/libxslt/extra.h +72 -0
- data/ext/nokogiri/include/libxslt/functions.h +78 -0
- data/ext/nokogiri/include/libxslt/imports.h +75 -0
- data/ext/nokogiri/include/libxslt/keys.h +53 -0
- data/ext/nokogiri/include/libxslt/namespaces.h +68 -0
- data/ext/nokogiri/include/libxslt/numbersInternals.h +73 -0
- data/ext/nokogiri/include/libxslt/pattern.h +84 -0
- data/ext/nokogiri/include/libxslt/preproc.h +43 -0
- data/ext/nokogiri/include/libxslt/security.h +104 -0
- data/ext/nokogiri/include/libxslt/templates.h +77 -0
- data/ext/nokogiri/include/libxslt/transform.h +207 -0
- data/ext/nokogiri/include/libxslt/variables.h +118 -0
- data/ext/nokogiri/include/libxslt/xslt.h +110 -0
- data/ext/nokogiri/include/libxslt/xsltInternals.h +1978 -0
- data/ext/nokogiri/include/libxslt/xsltconfig.h +180 -0
- data/ext/nokogiri/include/libxslt/xsltexports.h +142 -0
- data/ext/nokogiri/include/libxslt/xsltlocale.h +76 -0
- data/ext/nokogiri/include/libxslt/xsltutils.h +313 -0
- data/ext/nokogiri/nokogiri.c +37 -46
- data/ext/nokogiri/nokogiri.h +25 -17
- data/ext/nokogiri/test_global_handlers.c +41 -0
- data/ext/nokogiri/xml_document.c +8 -3
- data/ext/nokogiri/xml_io.c +8 -6
- data/ext/nokogiri/xml_node.c +1 -1
- data/ext/nokogiri/xml_node_set.c +1 -1
- data/ext/nokogiri/xml_reader.c +6 -17
- data/ext/nokogiri/xml_relax_ng.c +29 -11
- data/ext/nokogiri/xml_sax_parser.c +2 -7
- data/ext/nokogiri/xml_sax_parser_context.c +4 -2
- data/ext/nokogiri/xml_sax_push_parser.c +2 -0
- data/ext/nokogiri/xml_schema.c +84 -13
- data/ext/nokogiri/xml_syntax_error.c +23 -0
- data/ext/nokogiri/xml_syntax_error.h +15 -3
- data/ext/nokogiri/xml_xpath_context.c +80 -4
- data/ext/nokogiri/xslt_stylesheet.c +1 -4
- data/lib/nokogiri.rb +20 -3
- data/lib/nokogiri/2.5/nokogiri.so +0 -0
- data/lib/nokogiri/2.6/nokogiri.so +0 -0
- data/lib/nokogiri/2.7/nokogiri.so +0 -0
- data/lib/nokogiri/3.0/nokogiri.so +0 -0
- data/lib/nokogiri/css/parser.rb +62 -62
- data/lib/nokogiri/css/parser.y +2 -2
- data/lib/nokogiri/css/parser_extras.rb +38 -36
- data/lib/nokogiri/css/xpath_visitor.rb +70 -42
- data/lib/nokogiri/html/document.rb +12 -26
- data/lib/nokogiri/version.rb +2 -148
- data/lib/nokogiri/version/constant.rb +5 -0
- data/lib/nokogiri/version/info.rb +182 -0
- data/lib/nokogiri/xml/builder.rb +2 -2
- data/lib/nokogiri/xml/document.rb +17 -7
- data/lib/nokogiri/xml/document_fragment.rb +4 -6
- data/lib/nokogiri/xml/node.rb +562 -238
- data/lib/nokogiri/xml/parse_options.rb +6 -0
- data/lib/nokogiri/xml/relax_ng.rb +6 -2
- data/lib/nokogiri/xml/schema.rb +12 -4
- data/lib/nokogiri/xml/searchable.rb +24 -16
- metadata +149 -130
- data/lib/nokogiri/2.4/nokogiri.so +0 -0
Binary file
|
Binary file
|
Binary file
|
Binary file
|
data/lib/nokogiri/css/parser.rb
CHANGED
@@ -1,8 +1,8 @@
|
|
1
1
|
# frozen_string_literal: true
|
2
2
|
#
|
3
3
|
# DO NOT MODIFY!!!!
|
4
|
-
# This file is automatically generated by Racc 1.
|
5
|
-
# from Racc
|
4
|
+
# This file is automatically generated by Racc 1.5.1
|
5
|
+
# from Racc grammar file "".
|
6
6
|
#
|
7
7
|
|
8
8
|
require 'racc/parser.rb'
|
@@ -334,42 +334,42 @@ Racc_debug_parser = false
|
|
334
334
|
|
335
335
|
def _reduce_1(val, _values, result)
|
336
336
|
result = [val.first, val.last].flatten
|
337
|
-
|
337
|
+
|
338
338
|
result
|
339
339
|
end
|
340
340
|
|
341
341
|
def _reduce_2(val, _values, result)
|
342
|
-
result = val.flatten
|
342
|
+
result = val.flatten
|
343
343
|
result
|
344
344
|
end
|
345
345
|
|
346
346
|
def _reduce_3(val, _values, result)
|
347
|
-
result = [val.last].flatten
|
347
|
+
result = [val.last].flatten
|
348
348
|
result
|
349
349
|
end
|
350
350
|
|
351
351
|
def _reduce_4(val, _values, result)
|
352
|
-
result = :DIRECT_ADJACENT_SELECTOR
|
352
|
+
result = :DIRECT_ADJACENT_SELECTOR
|
353
353
|
result
|
354
354
|
end
|
355
355
|
|
356
356
|
def _reduce_5(val, _values, result)
|
357
|
-
result = :CHILD_SELECTOR
|
357
|
+
result = :CHILD_SELECTOR
|
358
358
|
result
|
359
359
|
end
|
360
360
|
|
361
361
|
def _reduce_6(val, _values, result)
|
362
|
-
result = :FOLLOWING_SELECTOR
|
362
|
+
result = :FOLLOWING_SELECTOR
|
363
363
|
result
|
364
364
|
end
|
365
365
|
|
366
366
|
def _reduce_7(val, _values, result)
|
367
|
-
result = :DESCENDANT_SELECTOR
|
367
|
+
result = :DESCENDANT_SELECTOR
|
368
368
|
result
|
369
369
|
end
|
370
370
|
|
371
371
|
def _reduce_8(val, _values, result)
|
372
|
-
result = :CHILD_SELECTOR
|
372
|
+
result = :CHILD_SELECTOR
|
373
373
|
result
|
374
374
|
end
|
375
375
|
|
@@ -379,7 +379,7 @@ def _reduce_9(val, _values, result)
|
|
379
379
|
else
|
380
380
|
Node.new(:CONDITIONAL_SELECTOR, [val.first, val[1]])
|
381
381
|
end
|
382
|
-
|
382
|
+
|
383
383
|
result
|
384
384
|
end
|
385
385
|
|
@@ -387,13 +387,13 @@ end
|
|
387
387
|
|
388
388
|
def _reduce_11(val, _values, result)
|
389
389
|
result = Node.new(:CONDITIONAL_SELECTOR, val)
|
390
|
-
|
390
|
+
|
391
391
|
result
|
392
392
|
end
|
393
393
|
|
394
394
|
def _reduce_12(val, _values, result)
|
395
395
|
result = Node.new(:CONDITIONAL_SELECTOR, val)
|
396
|
-
|
396
|
+
|
397
397
|
result
|
398
398
|
end
|
399
399
|
|
@@ -401,39 +401,39 @@ def _reduce_13(val, _values, result)
|
|
401
401
|
result = Node.new(:CONDITIONAL_SELECTOR,
|
402
402
|
[Node.new(:ELEMENT_NAME, ['*']), val.first]
|
403
403
|
)
|
404
|
-
|
404
|
+
|
405
405
|
result
|
406
406
|
end
|
407
407
|
|
408
408
|
def _reduce_14(val, _values, result)
|
409
409
|
result = Node.new(val.first, [nil, val.last])
|
410
|
-
|
410
|
+
|
411
411
|
result
|
412
412
|
end
|
413
413
|
|
414
414
|
def _reduce_15(val, _values, result)
|
415
415
|
result = Node.new(val[1], [val.first, val.last])
|
416
|
-
|
416
|
+
|
417
417
|
result
|
418
418
|
end
|
419
419
|
|
420
420
|
def _reduce_16(val, _values, result)
|
421
421
|
result = Node.new(:DESCENDANT_SELECTOR, [val.first, val.last])
|
422
|
-
|
422
|
+
|
423
423
|
result
|
424
424
|
end
|
425
425
|
|
426
426
|
# reduce 17 omitted
|
427
427
|
|
428
428
|
def _reduce_18(val, _values, result)
|
429
|
-
result = Node.new(:CLASS_CONDITION, [unescape_css_identifier(val[1])])
|
429
|
+
result = Node.new(:CLASS_CONDITION, [unescape_css_identifier(val[1])])
|
430
430
|
result
|
431
431
|
end
|
432
432
|
|
433
433
|
# reduce 19 omitted
|
434
434
|
|
435
435
|
def _reduce_20(val, _values, result)
|
436
|
-
result = Node.new(:ELEMENT_NAME, val)
|
436
|
+
result = Node.new(:ELEMENT_NAME, val)
|
437
437
|
result
|
438
438
|
end
|
439
439
|
|
@@ -441,19 +441,19 @@ def _reduce_21(val, _values, result)
|
|
441
441
|
result = Node.new(:ELEMENT_NAME,
|
442
442
|
[[val.first, val.last].compact.join(':')]
|
443
443
|
)
|
444
|
-
|
444
|
+
|
445
445
|
result
|
446
446
|
end
|
447
447
|
|
448
448
|
def _reduce_22(val, _values, result)
|
449
449
|
name = @namespaces.key?('xmlns') ? "xmlns:#{val.first}" : val.first
|
450
450
|
result = Node.new(:ELEMENT_NAME, [name])
|
451
|
-
|
451
|
+
|
452
452
|
result
|
453
453
|
end
|
454
454
|
|
455
455
|
def _reduce_23(val, _values, result)
|
456
|
-
result = val[0]
|
456
|
+
result = val[0]
|
457
457
|
result
|
458
458
|
end
|
459
459
|
|
@@ -463,7 +463,7 @@ def _reduce_25(val, _values, result)
|
|
463
463
|
result = Node.new(:ATTRIBUTE_CONDITION,
|
464
464
|
[val[1]] + (val[2] || [])
|
465
465
|
)
|
466
|
-
|
466
|
+
|
467
467
|
result
|
468
468
|
end
|
469
469
|
|
@@ -471,16 +471,16 @@ def _reduce_26(val, _values, result)
|
|
471
471
|
result = Node.new(:ATTRIBUTE_CONDITION,
|
472
472
|
[val[1]] + (val[2] || [])
|
473
473
|
)
|
474
|
-
|
474
|
+
|
475
475
|
result
|
476
476
|
end
|
477
477
|
|
478
478
|
def _reduce_27(val, _values, result)
|
479
|
-
#
|
479
|
+
# non-standard, from hpricot
|
480
480
|
result = Node.new(:PSEUDO_CLASS,
|
481
481
|
[Node.new(:FUNCTION, ['nth-child(', val[1]])]
|
482
482
|
)
|
483
|
-
|
483
|
+
|
484
484
|
result
|
485
485
|
end
|
486
486
|
|
@@ -488,7 +488,7 @@ def _reduce_28(val, _values, result)
|
|
488
488
|
result = Node.new(:ELEMENT_NAME,
|
489
489
|
[[val.first, val.last].compact.join(':')]
|
490
490
|
)
|
491
|
-
|
491
|
+
|
492
492
|
result
|
493
493
|
end
|
494
494
|
|
@@ -496,52 +496,52 @@ def _reduce_29(val, _values, result)
|
|
496
496
|
# Default namespace is not applied to attributes.
|
497
497
|
# So we don't add prefix "xmlns:" as in namespaced_ident.
|
498
498
|
result = Node.new(:ELEMENT_NAME, [val.first])
|
499
|
-
|
499
|
+
|
500
500
|
result
|
501
501
|
end
|
502
502
|
|
503
503
|
def _reduce_30(val, _values, result)
|
504
504
|
result = Node.new(:FUNCTION, [val.first.strip])
|
505
|
-
|
505
|
+
|
506
506
|
result
|
507
507
|
end
|
508
508
|
|
509
509
|
def _reduce_31(val, _values, result)
|
510
510
|
result = Node.new(:FUNCTION, [val.first.strip, val[1]].flatten)
|
511
|
-
|
511
|
+
|
512
512
|
result
|
513
513
|
end
|
514
514
|
|
515
515
|
def _reduce_32(val, _values, result)
|
516
516
|
result = Node.new(:FUNCTION, [val.first.strip, val[1]].flatten)
|
517
|
-
|
517
|
+
|
518
518
|
result
|
519
519
|
end
|
520
520
|
|
521
521
|
def _reduce_33(val, _values, result)
|
522
522
|
result = Node.new(:FUNCTION, [val.first.strip, val[1]].flatten)
|
523
|
-
|
523
|
+
|
524
524
|
result
|
525
525
|
end
|
526
526
|
|
527
527
|
def _reduce_34(val, _values, result)
|
528
528
|
result = Node.new(:FUNCTION, [val.first.strip, val[1]].flatten)
|
529
|
-
|
529
|
+
|
530
530
|
result
|
531
531
|
end
|
532
532
|
|
533
533
|
def _reduce_35(val, _values, result)
|
534
|
-
result = [val.first, val.last]
|
534
|
+
result = [val.first, val.last]
|
535
535
|
result
|
536
536
|
end
|
537
537
|
|
538
538
|
def _reduce_36(val, _values, result)
|
539
|
-
result = [val.first, val.last]
|
539
|
+
result = [val.first, val.last]
|
540
540
|
result
|
541
541
|
end
|
542
542
|
|
543
543
|
def _reduce_37(val, _values, result)
|
544
|
-
result = [val.first, val.last]
|
544
|
+
result = [val.first, val.last]
|
545
545
|
result
|
546
546
|
end
|
547
547
|
|
@@ -558,13 +558,13 @@ def _reduce_40(val, _values, result)
|
|
558
558
|
when 'n'
|
559
559
|
result = Node.new(:NTH, ['1','n','+','0'])
|
560
560
|
else
|
561
|
-
#
|
561
|
+
# non-standard to support custom functions:
|
562
562
|
# assert_xpath("//a[foo(., @href)]", @parser.parse('a:foo(@href)'))
|
563
563
|
# assert_xpath("//a[foo(., @a, b)]", @parser.parse('a:foo(@a, b)'))
|
564
564
|
# assert_xpath("//a[foo(., a, 10)]", @parser.parse('a:foo(a, 10)'))
|
565
565
|
result = val
|
566
566
|
end
|
567
|
-
|
567
|
+
|
568
568
|
result
|
569
569
|
end
|
570
570
|
|
@@ -574,7 +574,7 @@ def _reduce_41(val, _values, result)
|
|
574
574
|
else
|
575
575
|
raise Racc::ParseError, "parse error on IDENT '#{val[1]}'"
|
576
576
|
end
|
577
|
-
|
577
|
+
|
578
578
|
result
|
579
579
|
end
|
580
580
|
|
@@ -590,7 +590,7 @@ def _reduce_42(val, _values, result)
|
|
590
590
|
else
|
591
591
|
raise Racc::ParseError, "parse error on IDENT '#{val[1]}'"
|
592
592
|
end
|
593
|
-
|
593
|
+
|
594
594
|
result
|
595
595
|
end
|
596
596
|
|
@@ -610,18 +610,18 @@ def _reduce_43(val, _values, result)
|
|
610
610
|
else
|
611
611
|
raise Racc::ParseError, "parse error on IDENT '#{val[1]}'"
|
612
612
|
end
|
613
|
-
|
613
|
+
|
614
614
|
result
|
615
615
|
end
|
616
616
|
|
617
617
|
def _reduce_44(val, _values, result)
|
618
618
|
result = Node.new(:PSEUDO_CLASS, [val[1]])
|
619
|
-
|
619
|
+
|
620
620
|
result
|
621
621
|
end
|
622
622
|
|
623
623
|
def _reduce_45(val, _values, result)
|
624
|
-
result = Node.new(:PSEUDO_CLASS, [val[1]])
|
624
|
+
result = Node.new(:PSEUDO_CLASS, [val[1]])
|
625
625
|
result
|
626
626
|
end
|
627
627
|
|
@@ -631,31 +631,31 @@ end
|
|
631
631
|
|
632
632
|
def _reduce_48(val, _values, result)
|
633
633
|
result = Node.new(:COMBINATOR, val)
|
634
|
-
|
634
|
+
|
635
635
|
result
|
636
636
|
end
|
637
637
|
|
638
638
|
def _reduce_49(val, _values, result)
|
639
639
|
result = Node.new(:COMBINATOR, val)
|
640
|
-
|
640
|
+
|
641
641
|
result
|
642
642
|
end
|
643
643
|
|
644
644
|
def _reduce_50(val, _values, result)
|
645
645
|
result = Node.new(:COMBINATOR, val)
|
646
|
-
|
646
|
+
|
647
647
|
result
|
648
648
|
end
|
649
649
|
|
650
650
|
def _reduce_51(val, _values, result)
|
651
651
|
result = Node.new(:COMBINATOR, val)
|
652
|
-
|
652
|
+
|
653
653
|
result
|
654
654
|
end
|
655
655
|
|
656
656
|
def _reduce_52(val, _values, result)
|
657
657
|
result = Node.new(:COMBINATOR, val)
|
658
|
-
|
658
|
+
|
659
659
|
result
|
660
660
|
end
|
661
661
|
|
@@ -670,65 +670,65 @@ end
|
|
670
670
|
# reduce 57 omitted
|
671
671
|
|
672
672
|
def _reduce_58(val, _values, result)
|
673
|
-
result = Node.new(:ID, [unescape_css_identifier(val.first)])
|
673
|
+
result = Node.new(:ID, [unescape_css_identifier(val.first)])
|
674
674
|
result
|
675
675
|
end
|
676
676
|
|
677
677
|
def _reduce_59(val, _values, result)
|
678
|
-
result = [val.first, unescape_css_identifier(val[1])]
|
678
|
+
result = [val.first, unescape_css_identifier(val[1])]
|
679
679
|
result
|
680
680
|
end
|
681
681
|
|
682
682
|
def _reduce_60(val, _values, result)
|
683
|
-
result = [val.first, unescape_css_string(val[1])]
|
683
|
+
result = [val.first, unescape_css_string(val[1])]
|
684
684
|
result
|
685
685
|
end
|
686
686
|
|
687
687
|
def _reduce_61(val, _values, result)
|
688
|
-
result = [val.first, val[1]]
|
688
|
+
result = [val.first, val[1]]
|
689
689
|
result
|
690
690
|
end
|
691
691
|
|
692
692
|
# reduce 62 omitted
|
693
693
|
|
694
694
|
def _reduce_63(val, _values, result)
|
695
|
-
result = :equal
|
695
|
+
result = :equal
|
696
696
|
result
|
697
697
|
end
|
698
698
|
|
699
699
|
def _reduce_64(val, _values, result)
|
700
|
-
result = :prefix_match
|
700
|
+
result = :prefix_match
|
701
701
|
result
|
702
702
|
end
|
703
703
|
|
704
704
|
def _reduce_65(val, _values, result)
|
705
|
-
result = :suffix_match
|
705
|
+
result = :suffix_match
|
706
706
|
result
|
707
707
|
end
|
708
708
|
|
709
709
|
def _reduce_66(val, _values, result)
|
710
|
-
result = :substring_match
|
710
|
+
result = :substring_match
|
711
711
|
result
|
712
712
|
end
|
713
713
|
|
714
714
|
def _reduce_67(val, _values, result)
|
715
|
-
result = :not_equal
|
715
|
+
result = :not_equal
|
716
716
|
result
|
717
717
|
end
|
718
718
|
|
719
719
|
def _reduce_68(val, _values, result)
|
720
|
-
result = :includes
|
720
|
+
result = :includes
|
721
721
|
result
|
722
722
|
end
|
723
723
|
|
724
724
|
def _reduce_69(val, _values, result)
|
725
|
-
result = :dash_match
|
725
|
+
result = :dash_match
|
726
726
|
result
|
727
727
|
end
|
728
728
|
|
729
729
|
def _reduce_70(val, _values, result)
|
730
730
|
result = Node.new(:NOT, [val[1]])
|
731
|
-
|
731
|
+
|
732
732
|
result
|
733
733
|
end
|
734
734
|
|
@@ -747,5 +747,5 @@ def _reduce_none(val, _values, result)
|
|
747
747
|
end
|
748
748
|
|
749
749
|
end # class Parser
|
750
|
-
|
751
|
-
|
750
|
+
end # module CSS
|
751
|
+
end # module Nokogiri
|
data/lib/nokogiri/css/parser.y
CHANGED
@@ -88,7 +88,7 @@ rule
|
|
88
88
|
)
|
89
89
|
}
|
90
90
|
| LSQUARE NUMBER RSQUARE {
|
91
|
-
#
|
91
|
+
# non-standard, from hpricot
|
92
92
|
result = Node.new(:PSEUDO_CLASS,
|
93
93
|
[Node.new(:FUNCTION, ['nth-child(', val[1]])]
|
94
94
|
)
|
@@ -139,7 +139,7 @@ rule
|
|
139
139
|
when 'n'
|
140
140
|
result = Node.new(:NTH, ['1','n','+','0'])
|
141
141
|
else
|
142
|
-
#
|
142
|
+
# non-standard to support custom functions:
|
143
143
|
# assert_xpath("//a[foo(., @href)]", @parser.parse('a:foo(@href)'))
|
144
144
|
# assert_xpath("//a[foo(., @a, b)]", @parser.parse('a:foo(@a, b)'))
|
145
145
|
# assert_xpath("//a[foo(., a, 10)]", @parser.parse('a:foo(a, 10)'))
|