nokogiri 1.5.10 → 1.13.0

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.

Files changed (334) hide show
  1. checksums.yaml +7 -0
  2. data/Gemfile +5 -0
  3. data/LICENSE-DEPENDENCIES.md +1903 -0
  4. data/LICENSE.md +9 -0
  5. data/README.md +280 -0
  6. data/bin/nokogiri +84 -31
  7. data/dependencies.yml +73 -0
  8. data/ext/nokogiri/depend +38 -358
  9. data/ext/nokogiri/extconf.rb +956 -100
  10. data/ext/nokogiri/gumbo.c +584 -0
  11. data/ext/nokogiri/html4_document.c +166 -0
  12. data/ext/nokogiri/html4_element_description.c +294 -0
  13. data/ext/nokogiri/html4_entity_lookup.c +37 -0
  14. data/ext/nokogiri/html4_sax_parser_context.c +120 -0
  15. data/ext/nokogiri/html4_sax_push_parser.c +95 -0
  16. data/ext/nokogiri/libxml2_backwards_compat.c +121 -0
  17. data/ext/nokogiri/nokogiri.c +232 -87
  18. data/ext/nokogiri/nokogiri.h +188 -129
  19. data/ext/nokogiri/test_global_handlers.c +40 -0
  20. data/ext/nokogiri/xml_attr.c +49 -40
  21. data/ext/nokogiri/xml_attribute_decl.c +18 -18
  22. data/ext/nokogiri/xml_cdata.c +24 -23
  23. data/ext/nokogiri/xml_comment.c +29 -21
  24. data/ext/nokogiri/xml_document.c +327 -223
  25. data/ext/nokogiri/xml_document_fragment.c +12 -16
  26. data/ext/nokogiri/xml_dtd.c +56 -50
  27. data/ext/nokogiri/xml_element_content.c +31 -26
  28. data/ext/nokogiri/xml_element_decl.c +22 -22
  29. data/ext/nokogiri/xml_encoding_handler.c +45 -20
  30. data/ext/nokogiri/xml_entity_decl.c +32 -30
  31. data/ext/nokogiri/xml_entity_reference.c +16 -18
  32. data/ext/nokogiri/xml_namespace.c +74 -32
  33. data/ext/nokogiri/xml_node.c +1290 -680
  34. data/ext/nokogiri/xml_node_set.c +239 -208
  35. data/ext/nokogiri/xml_processing_instruction.c +17 -19
  36. data/ext/nokogiri/xml_reader.c +227 -189
  37. data/ext/nokogiri/xml_relax_ng.c +52 -28
  38. data/ext/nokogiri/xml_sax_parser.c +123 -125
  39. data/ext/nokogiri/xml_sax_parser_context.c +138 -79
  40. data/ext/nokogiri/xml_sax_push_parser.c +88 -35
  41. data/ext/nokogiri/xml_schema.c +112 -33
  42. data/ext/nokogiri/xml_syntax_error.c +50 -23
  43. data/ext/nokogiri/xml_text.c +14 -18
  44. data/ext/nokogiri/xml_xpath_context.c +227 -140
  45. data/ext/nokogiri/xslt_stylesheet.c +162 -168
  46. data/gumbo-parser/CHANGES.md +63 -0
  47. data/gumbo-parser/Makefile +101 -0
  48. data/gumbo-parser/THANKS +27 -0
  49. data/gumbo-parser/src/Makefile +34 -0
  50. data/gumbo-parser/src/README.md +41 -0
  51. data/gumbo-parser/src/ascii.c +75 -0
  52. data/gumbo-parser/src/ascii.h +115 -0
  53. data/gumbo-parser/src/attribute.c +42 -0
  54. data/gumbo-parser/src/attribute.h +17 -0
  55. data/gumbo-parser/src/char_ref.c +22225 -0
  56. data/gumbo-parser/src/char_ref.h +29 -0
  57. data/gumbo-parser/src/char_ref.rl +2154 -0
  58. data/gumbo-parser/src/error.c +626 -0
  59. data/gumbo-parser/src/error.h +148 -0
  60. data/gumbo-parser/src/foreign_attrs.c +104 -0
  61. data/gumbo-parser/src/foreign_attrs.gperf +27 -0
  62. data/gumbo-parser/src/gumbo.h +943 -0
  63. data/gumbo-parser/src/insertion_mode.h +33 -0
  64. data/gumbo-parser/src/macros.h +91 -0
  65. data/gumbo-parser/src/parser.c +4875 -0
  66. data/gumbo-parser/src/parser.h +41 -0
  67. data/gumbo-parser/src/replacement.h +33 -0
  68. data/gumbo-parser/src/string_buffer.c +103 -0
  69. data/gumbo-parser/src/string_buffer.h +68 -0
  70. data/gumbo-parser/src/string_piece.c +48 -0
  71. data/gumbo-parser/src/svg_attrs.c +174 -0
  72. data/gumbo-parser/src/svg_attrs.gperf +77 -0
  73. data/gumbo-parser/src/svg_tags.c +137 -0
  74. data/gumbo-parser/src/svg_tags.gperf +55 -0
  75. data/gumbo-parser/src/tag.c +222 -0
  76. data/gumbo-parser/src/tag_lookup.c +382 -0
  77. data/gumbo-parser/src/tag_lookup.gperf +169 -0
  78. data/gumbo-parser/src/tag_lookup.h +13 -0
  79. data/gumbo-parser/src/token_buffer.c +79 -0
  80. data/gumbo-parser/src/token_buffer.h +71 -0
  81. data/gumbo-parser/src/token_type.h +17 -0
  82. data/gumbo-parser/src/tokenizer.c +3463 -0
  83. data/gumbo-parser/src/tokenizer.h +112 -0
  84. data/gumbo-parser/src/tokenizer_states.h +339 -0
  85. data/gumbo-parser/src/utf8.c +245 -0
  86. data/gumbo-parser/src/utf8.h +164 -0
  87. data/gumbo-parser/src/util.c +68 -0
  88. data/gumbo-parser/src/util.h +30 -0
  89. data/gumbo-parser/src/vector.c +111 -0
  90. data/gumbo-parser/src/vector.h +45 -0
  91. data/lib/nokogiri/class_resolver.rb +67 -0
  92. data/lib/nokogiri/css/node.rb +10 -58
  93. data/lib/nokogiri/css/parser.rb +327 -288
  94. data/lib/nokogiri/css/parser.y +67 -45
  95. data/lib/nokogiri/css/parser_extras.rb +52 -49
  96. data/lib/nokogiri/css/syntax_error.rb +3 -1
  97. data/lib/nokogiri/css/tokenizer.rb +107 -104
  98. data/lib/nokogiri/css/tokenizer.rex +7 -6
  99. data/lib/nokogiri/css/xpath_visitor.rb +263 -75
  100. data/lib/nokogiri/css.rb +50 -17
  101. data/lib/nokogiri/decorators/slop.rb +17 -8
  102. data/lib/nokogiri/extension.rb +31 -0
  103. data/lib/nokogiri/gumbo.rb +15 -0
  104. data/lib/nokogiri/html.rb +38 -27
  105. data/lib/nokogiri/{html → html4}/builder.rb +4 -2
  106. data/lib/nokogiri/html4/document.rb +331 -0
  107. data/lib/nokogiri/html4/document_fragment.rb +54 -0
  108. data/lib/nokogiri/{html → html4}/element_description.rb +3 -1
  109. data/lib/nokogiri/html4/element_description_defaults.rb +578 -0
  110. data/lib/nokogiri/{html → html4}/entity_lookup.rb +4 -2
  111. data/lib/nokogiri/{html → html4}/sax/parser.rb +24 -15
  112. data/lib/nokogiri/html4/sax/parser_context.rb +20 -0
  113. data/lib/nokogiri/html4/sax/push_parser.rb +37 -0
  114. data/lib/nokogiri/html4.rb +46 -0
  115. data/lib/nokogiri/html5/document.rb +88 -0
  116. data/lib/nokogiri/html5/document_fragment.rb +83 -0
  117. data/lib/nokogiri/html5/node.rb +96 -0
  118. data/lib/nokogiri/html5.rb +477 -0
  119. data/lib/nokogiri/jruby/dependencies.rb +21 -0
  120. data/lib/nokogiri/syntax_error.rb +2 -0
  121. data/lib/nokogiri/version/constant.rb +6 -0
  122. data/lib/nokogiri/version/info.rb +221 -0
  123. data/lib/nokogiri/version.rb +3 -90
  124. data/lib/nokogiri/xml/attr.rb +6 -3
  125. data/lib/nokogiri/xml/attribute_decl.rb +3 -1
  126. data/lib/nokogiri/xml/builder.rb +96 -54
  127. data/lib/nokogiri/xml/cdata.rb +3 -1
  128. data/lib/nokogiri/xml/character_data.rb +2 -0
  129. data/lib/nokogiri/xml/document.rb +234 -95
  130. data/lib/nokogiri/xml/document_fragment.rb +86 -36
  131. data/lib/nokogiri/xml/dtd.rb +16 -4
  132. data/lib/nokogiri/xml/element_content.rb +2 -0
  133. data/lib/nokogiri/xml/element_decl.rb +3 -1
  134. data/lib/nokogiri/xml/entity_decl.rb +4 -2
  135. data/lib/nokogiri/xml/entity_reference.rb +20 -0
  136. data/lib/nokogiri/xml/namespace.rb +3 -0
  137. data/lib/nokogiri/xml/node/save_options.rb +8 -4
  138. data/lib/nokogiri/xml/node.rb +947 -502
  139. data/lib/nokogiri/xml/node_set.rb +168 -159
  140. data/lib/nokogiri/xml/notation.rb +13 -0
  141. data/lib/nokogiri/xml/parse_options.rb +40 -5
  142. data/lib/nokogiri/xml/pp/character_data.rb +9 -6
  143. data/lib/nokogiri/xml/pp/node.rb +25 -26
  144. data/lib/nokogiri/xml/pp.rb +4 -2
  145. data/lib/nokogiri/xml/processing_instruction.rb +3 -1
  146. data/lib/nokogiri/xml/reader.rb +23 -28
  147. data/lib/nokogiri/xml/relax_ng.rb +8 -2
  148. data/lib/nokogiri/xml/sax/document.rb +45 -49
  149. data/lib/nokogiri/xml/sax/parser.rb +43 -41
  150. data/lib/nokogiri/xml/sax/parser_context.rb +8 -3
  151. data/lib/nokogiri/xml/sax/push_parser.rb +6 -5
  152. data/lib/nokogiri/xml/sax.rb +6 -4
  153. data/lib/nokogiri/xml/schema.rb +19 -9
  154. data/lib/nokogiri/xml/searchable.rb +259 -0
  155. data/lib/nokogiri/xml/syntax_error.rb +25 -1
  156. data/lib/nokogiri/xml/text.rb +2 -0
  157. data/lib/nokogiri/xml/xpath/syntax_error.rb +4 -2
  158. data/lib/nokogiri/xml/xpath.rb +15 -4
  159. data/lib/nokogiri/xml/xpath_context.rb +3 -3
  160. data/lib/nokogiri/xml.rb +38 -36
  161. data/lib/nokogiri/xslt/stylesheet.rb +3 -1
  162. data/lib/nokogiri/xslt.rb +18 -16
  163. data/lib/nokogiri.rb +69 -69
  164. data/lib/xsd/xmlparser/nokogiri.rb +26 -24
  165. data/patches/libxml2/0001-Remove-script-macro-support.patch +40 -0
  166. data/patches/libxml2/0002-Update-entities-to-remove-handling-of-ssi.patch +44 -0
  167. data/patches/libxml2/0003-libxml2.la-is-in-top_builddir.patch +25 -0
  168. data/patches/libxml2/0004-use-glibc-strlen.patch +53 -0
  169. data/patches/libxml2/0005-avoid-isnan-isinf.patch +81 -0
  170. data/patches/libxml2/0006-update-automake-files-for-arm64.patch +2511 -0
  171. data/patches/libxml2/0007-Fix-XPath-recursion-limit.patch +31 -0
  172. data/patches/libxml2/0008-htmlParseComment-handle-abruptly-closed-comments.patch +61 -0
  173. data/patches/libxml2/0009-allow-wildcard-namespaces.patch +77 -0
  174. data/patches/libxslt/0001-update-automake-files-for-arm64.patch +2511 -0
  175. data/patches/libxslt/0002-Fix-xml2-config-check-in-configure-script.patch +19 -0
  176. data/ports/archives/libxml2-2.9.12.tar.gz +0 -0
  177. data/ports/archives/libxslt-1.1.34.tar.gz +0 -0
  178. metadata +382 -460
  179. data/.autotest +0 -26
  180. data/.gemtest +0 -0
  181. data/CHANGELOG.ja.rdoc +0 -785
  182. data/CHANGELOG.rdoc +0 -783
  183. data/C_CODING_STYLE.rdoc +0 -33
  184. data/Manifest.txt +0 -303
  185. data/README.ja.rdoc +0 -106
  186. data/README.rdoc +0 -175
  187. data/ROADMAP.md +0 -90
  188. data/Rakefile +0 -228
  189. data/STANDARD_RESPONSES.md +0 -47
  190. data/Y_U_NO_GEMSPEC.md +0 -155
  191. data/build_all +0 -105
  192. data/ext/nokogiri/html_document.c +0 -170
  193. data/ext/nokogiri/html_document.h +0 -10
  194. data/ext/nokogiri/html_element_description.c +0 -279
  195. data/ext/nokogiri/html_element_description.h +0 -10
  196. data/ext/nokogiri/html_entity_lookup.c +0 -32
  197. data/ext/nokogiri/html_entity_lookup.h +0 -8
  198. data/ext/nokogiri/html_sax_parser_context.c +0 -116
  199. data/ext/nokogiri/html_sax_parser_context.h +0 -11
  200. data/ext/nokogiri/html_sax_push_parser.c +0 -87
  201. data/ext/nokogiri/html_sax_push_parser.h +0 -9
  202. data/ext/nokogiri/xml_attr.h +0 -9
  203. data/ext/nokogiri/xml_attribute_decl.h +0 -9
  204. data/ext/nokogiri/xml_cdata.h +0 -9
  205. data/ext/nokogiri/xml_comment.h +0 -9
  206. data/ext/nokogiri/xml_document.h +0 -23
  207. data/ext/nokogiri/xml_document_fragment.h +0 -10
  208. data/ext/nokogiri/xml_dtd.h +0 -10
  209. data/ext/nokogiri/xml_element_content.h +0 -10
  210. data/ext/nokogiri/xml_element_decl.h +0 -9
  211. data/ext/nokogiri/xml_encoding_handler.h +0 -8
  212. data/ext/nokogiri/xml_entity_decl.h +0 -10
  213. data/ext/nokogiri/xml_entity_reference.h +0 -9
  214. data/ext/nokogiri/xml_io.c +0 -56
  215. data/ext/nokogiri/xml_io.h +0 -11
  216. data/ext/nokogiri/xml_libxml2_hacks.c +0 -112
  217. data/ext/nokogiri/xml_libxml2_hacks.h +0 -12
  218. data/ext/nokogiri/xml_namespace.h +0 -13
  219. data/ext/nokogiri/xml_node.h +0 -13
  220. data/ext/nokogiri/xml_node_set.h +0 -14
  221. data/ext/nokogiri/xml_processing_instruction.h +0 -9
  222. data/ext/nokogiri/xml_reader.h +0 -10
  223. data/ext/nokogiri/xml_relax_ng.h +0 -9
  224. data/ext/nokogiri/xml_sax_parser.h +0 -39
  225. data/ext/nokogiri/xml_sax_parser_context.h +0 -10
  226. data/ext/nokogiri/xml_sax_push_parser.h +0 -9
  227. data/ext/nokogiri/xml_schema.h +0 -9
  228. data/ext/nokogiri/xml_syntax_error.h +0 -13
  229. data/ext/nokogiri/xml_text.h +0 -9
  230. data/ext/nokogiri/xml_xpath_context.h +0 -10
  231. data/ext/nokogiri/xslt_stylesheet.h +0 -14
  232. data/lib/nokogiri/html/document.rb +0 -254
  233. data/lib/nokogiri/html/document_fragment.rb +0 -41
  234. data/lib/nokogiri/html/element_description_defaults.rb +0 -671
  235. data/lib/nokogiri/html/sax/parser_context.rb +0 -16
  236. data/lib/nokogiri/html/sax/push_parser.rb +0 -16
  237. data/tasks/cross_compile.rb +0 -150
  238. data/tasks/nokogiri.org.rb +0 -24
  239. data/tasks/test.rb +0 -95
  240. data/test/css/test_nthiness.rb +0 -159
  241. data/test/css/test_parser.rb +0 -341
  242. data/test/css/test_tokenizer.rb +0 -198
  243. data/test/css/test_xpath_visitor.rb +0 -91
  244. data/test/decorators/test_slop.rb +0 -16
  245. data/test/files/2ch.html +0 -108
  246. data/test/files/address_book.rlx +0 -12
  247. data/test/files/address_book.xml +0 -10
  248. data/test/files/bar/bar.xsd +0 -4
  249. data/test/files/dont_hurt_em_why.xml +0 -422
  250. data/test/files/encoding.html +0 -82
  251. data/test/files/encoding.xhtml +0 -84
  252. data/test/files/exslt.xml +0 -8
  253. data/test/files/exslt.xslt +0 -35
  254. data/test/files/foo/foo.xsd +0 -4
  255. data/test/files/metacharset.html +0 -10
  256. data/test/files/noencoding.html +0 -47
  257. data/test/files/po.xml +0 -32
  258. data/test/files/po.xsd +0 -66
  259. data/test/files/shift_jis.html +0 -10
  260. data/test/files/shift_jis.xml +0 -5
  261. data/test/files/snuggles.xml +0 -3
  262. data/test/files/staff.dtd +0 -10
  263. data/test/files/staff.xml +0 -59
  264. data/test/files/staff.xslt +0 -32
  265. data/test/files/test_document_url/bar.xml +0 -2
  266. data/test/files/test_document_url/document.dtd +0 -4
  267. data/test/files/test_document_url/document.xml +0 -6
  268. data/test/files/tlm.html +0 -850
  269. data/test/files/to_be_xincluded.xml +0 -2
  270. data/test/files/valid_bar.xml +0 -2
  271. data/test/files/xinclude.xml +0 -4
  272. data/test/helper.rb +0 -154
  273. data/test/html/sax/test_parser.rb +0 -141
  274. data/test/html/sax/test_parser_context.rb +0 -46
  275. data/test/html/test_builder.rb +0 -164
  276. data/test/html/test_document.rb +0 -552
  277. data/test/html/test_document_encoding.rb +0 -138
  278. data/test/html/test_document_fragment.rb +0 -261
  279. data/test/html/test_element_description.rb +0 -105
  280. data/test/html/test_named_characters.rb +0 -14
  281. data/test/html/test_node.rb +0 -196
  282. data/test/html/test_node_encoding.rb +0 -27
  283. data/test/namespaces/test_additional_namespaces_in_builder_doc.rb +0 -14
  284. data/test/namespaces/test_namespaces_in_builder_doc.rb +0 -75
  285. data/test/namespaces/test_namespaces_in_created_doc.rb +0 -75
  286. data/test/namespaces/test_namespaces_in_parsed_doc.rb +0 -66
  287. data/test/test_convert_xpath.rb +0 -135
  288. data/test/test_css_cache.rb +0 -45
  289. data/test/test_encoding_handler.rb +0 -46
  290. data/test/test_memory_leak.rb +0 -156
  291. data/test/test_nokogiri.rb +0 -132
  292. data/test/test_reader.rb +0 -555
  293. data/test/test_soap4r_sax.rb +0 -52
  294. data/test/test_xslt_transforms.rb +0 -254
  295. data/test/xml/node/test_save_options.rb +0 -28
  296. data/test/xml/node/test_subclass.rb +0 -44
  297. data/test/xml/sax/test_parser.rb +0 -366
  298. data/test/xml/sax/test_parser_context.rb +0 -106
  299. data/test/xml/sax/test_push_parser.rb +0 -157
  300. data/test/xml/test_attr.rb +0 -64
  301. data/test/xml/test_attribute_decl.rb +0 -86
  302. data/test/xml/test_builder.rb +0 -306
  303. data/test/xml/test_c14n.rb +0 -151
  304. data/test/xml/test_cdata.rb +0 -48
  305. data/test/xml/test_comment.rb +0 -29
  306. data/test/xml/test_document.rb +0 -828
  307. data/test/xml/test_document_encoding.rb +0 -28
  308. data/test/xml/test_document_fragment.rb +0 -223
  309. data/test/xml/test_dtd.rb +0 -103
  310. data/test/xml/test_dtd_encoding.rb +0 -33
  311. data/test/xml/test_element_content.rb +0 -56
  312. data/test/xml/test_element_decl.rb +0 -73
  313. data/test/xml/test_entity_decl.rb +0 -122
  314. data/test/xml/test_entity_reference.rb +0 -245
  315. data/test/xml/test_namespace.rb +0 -95
  316. data/test/xml/test_node.rb +0 -1137
  317. data/test/xml/test_node_attributes.rb +0 -96
  318. data/test/xml/test_node_encoding.rb +0 -107
  319. data/test/xml/test_node_inheritance.rb +0 -32
  320. data/test/xml/test_node_reparenting.rb +0 -374
  321. data/test/xml/test_node_set.rb +0 -755
  322. data/test/xml/test_parse_options.rb +0 -64
  323. data/test/xml/test_processing_instruction.rb +0 -30
  324. data/test/xml/test_reader_encoding.rb +0 -142
  325. data/test/xml/test_relax_ng.rb +0 -60
  326. data/test/xml/test_schema.rb +0 -103
  327. data/test/xml/test_syntax_error.rb +0 -12
  328. data/test/xml/test_text.rb +0 -45
  329. data/test/xml/test_unparented_node.rb +0 -422
  330. data/test/xml/test_xinclude.rb +0 -83
  331. data/test/xml/test_xpath.rb +0 -295
  332. data/test/xslt/test_custom_functions.rb +0 -133
  333. data/test/xslt/test_exception_handling.rb +0 -37
  334. data/test_all +0 -81
@@ -1,11 +1,13 @@
1
+ # frozen_string_literal: true
2
+
1
3
  module Nokogiri
2
4
  module XML
3
5
  class << self
4
6
  ###
5
7
  # Create a new Nokogiri::XML::Schema object using a +string_or_io+
6
8
  # object.
7
- def Schema string_or_io
8
- Schema.new(string_or_io)
9
+ def Schema(string_or_io, options = ParseOptions::DEFAULT_SCHEMA)
10
+ Schema.new(string_or_io, options)
9
11
  end
10
12
  end
11
13
 
@@ -26,15 +28,23 @@ module Nokogiri
26
28
  # end
27
29
  #
28
30
  # The list of errors are Nokogiri::XML::SyntaxError objects.
31
+ #
32
+ # NOTE: As of v1.11.0, Schema treats inputs as UNTRUSTED by default, and so external entities
33
+ # are not resolved from the network (`http://` or `ftp://`). Previously, parsing treated
34
+ # documents as "trusted" by default which was counter to Nokogiri's "untrusted by default"
35
+ # security policy. If a document is trusted, then the caller may turn off the NONET option via
36
+ # the ParseOptions to re-enable external entity resolution over a network connection.
29
37
  class Schema
30
38
  # Errors while parsing the schema file
31
39
  attr_accessor :errors
40
+ # The Nokogiri::XML::ParseOptions used to parse the schema
41
+ attr_accessor :parse_options
32
42
 
33
43
  ###
34
44
  # Create a new Nokogiri::XML::Schema object using a +string_or_io+
35
45
  # object.
36
- def self.new string_or_io
37
- from_document Nokogiri::XML(string_or_io)
46
+ def self.new(string_or_io, options = ParseOptions::DEFAULT_SCHEMA)
47
+ from_document(Nokogiri::XML(string_or_io), options)
38
48
  end
39
49
 
40
50
  ###
@@ -42,9 +52,9 @@ module Nokogiri
42
52
  # Nokogiri::XML::Document object, or a filename. An Array of
43
53
  # Nokogiri::XML::SyntaxError objects found while validating the
44
54
  # +thing+ is returned.
45
- def validate thing
46
- if thing.is_a?(Nokogiri::XML::Document)
47
- validate_document(thing)
55
+ def validate(thing)
56
+ if thing.is_a?(Nokogiri::XML::Document)
57
+ validate_document(thing)
48
58
  elsif File.file?(thing)
49
59
  validate_file(thing)
50
60
  else
@@ -55,8 +65,8 @@ module Nokogiri
55
65
  ###
56
66
  # Returns true if +thing+ is a valid Nokogiri::XML::Document or
57
67
  # file.
58
- def valid? thing
59
- validate(thing).length == 0
68
+ def valid?(thing)
69
+ validate(thing).empty?
60
70
  end
61
71
  end
62
72
  end
@@ -0,0 +1,259 @@
1
+ # coding: utf-8
2
+ # frozen_string_literal: true
3
+
4
+ module Nokogiri
5
+ module XML
6
+ #
7
+ # The Searchable module declares the interface used for searching your DOM.
8
+ #
9
+ # It implements the public methods `search`, `css`, and `xpath`,
10
+ # as well as allowing specific implementations to specialize some
11
+ # of the important behaviors.
12
+ #
13
+ module Searchable
14
+ # Regular expression used by Searchable#search to determine if a query
15
+ # string is CSS or XPath
16
+ LOOKS_LIKE_XPATH = %r{^(\./|/|\.\.|\.$)}
17
+
18
+ # :section: Searching via XPath or CSS Queries
19
+
20
+ ###
21
+ # call-seq:
22
+ # search(*paths, [namespace-bindings, xpath-variable-bindings, custom-handler-class])
23
+ #
24
+ # Search this object for +paths+. +paths+ must be one or more XPath or CSS queries:
25
+ #
26
+ # node.search("div.employee", ".//title")
27
+ #
28
+ # A hash of namespace bindings may be appended:
29
+ #
30
+ # node.search('.//bike:tire', {'bike' => 'http://schwinn.com/'})
31
+ # node.search('bike|tire', {'bike' => 'http://schwinn.com/'})
32
+ #
33
+ # For XPath queries, a hash of variable bindings may also be
34
+ # appended to the namespace bindings. For example:
35
+ #
36
+ # node.search('.//address[@domestic=$value]', nil, {:value => 'Yes'})
37
+ #
38
+ # Custom XPath functions and CSS pseudo-selectors may also be
39
+ # defined. To define custom functions create a class and
40
+ # implement the function you want to define. The first argument
41
+ # to the method will be the current matching NodeSet. Any other
42
+ # arguments are ones that you pass in. Note that this class may
43
+ # appear anywhere in the argument list. For example:
44
+ #
45
+ # node.search('.//title[regex(., "\w+")]', 'div.employee:regex("[0-9]+")'
46
+ # Class.new {
47
+ # def regex node_set, regex
48
+ # node_set.find_all { |node| node['some_attribute'] =~ /#{regex}/ }
49
+ # end
50
+ # }.new
51
+ # )
52
+ #
53
+ # See Searchable#xpath and Searchable#css for further usage help.
54
+ def search(*args)
55
+ paths, handler, ns, binds = extract_params(args)
56
+
57
+ xpaths = paths.map(&:to_s).map do |path|
58
+ LOOKS_LIKE_XPATH.match?(path) ? path : xpath_query_from_css_rule(path, ns)
59
+ end.flatten.uniq
60
+
61
+ xpath(*(xpaths + [ns, handler, binds].compact))
62
+ end
63
+
64
+ alias_method :/, :search
65
+
66
+ ###
67
+ # call-seq:
68
+ # at(*paths, [namespace-bindings, xpath-variable-bindings, custom-handler-class])
69
+ #
70
+ # Search this object for +paths+, and return only the first
71
+ # result. +paths+ must be one or more XPath or CSS queries.
72
+ #
73
+ # See Searchable#search for more information.
74
+ def at(*args)
75
+ search(*args).first
76
+ end
77
+
78
+ alias_method :%, :at
79
+
80
+ ###
81
+ # call-seq:
82
+ # css(*rules, [namespace-bindings, custom-pseudo-class])
83
+ #
84
+ # Search this object for CSS +rules+. +rules+ must be one or more CSS
85
+ # selectors. For example:
86
+ #
87
+ # node.css('title')
88
+ # node.css('body h1.bold')
89
+ # node.css('div + p.green', 'div#one')
90
+ #
91
+ # A hash of namespace bindings may be appended. For example:
92
+ #
93
+ # node.css('bike|tire', {'bike' => 'http://schwinn.com/'})
94
+ #
95
+ # Custom CSS pseudo classes may also be defined. To define
96
+ # custom pseudo classes, create a class and implement the custom
97
+ # pseudo class you want defined. The first argument to the
98
+ # method will be the current matching NodeSet. Any other
99
+ # arguments are ones that you pass in. For example:
100
+ #
101
+ # node.css('title:regex("\w+")', Class.new {
102
+ # def regex node_set, regex
103
+ # node_set.find_all { |node| node['some_attribute'] =~ /#{regex}/ }
104
+ # end
105
+ # }.new)
106
+ #
107
+ # Note that the CSS query string is case-sensitive with regards
108
+ # to your document type. That is, if you're looking for "H1" in
109
+ # an HTML document, you'll never find anything, since HTML tags
110
+ # will match only lowercase CSS queries. However, "H1" might be
111
+ # found in an XML document, where tags names are case-sensitive
112
+ # (e.g., "H1" is distinct from "h1").
113
+ #
114
+ def css(*args)
115
+ rules, handler, ns, _ = extract_params(args)
116
+
117
+ css_internal(self, rules, handler, ns)
118
+ end
119
+
120
+ ##
121
+ # call-seq:
122
+ # at_css(*rules, [namespace-bindings, custom-pseudo-class])
123
+ #
124
+ # Search this object for CSS +rules+, and return only the first
125
+ # match. +rules+ must be one or more CSS selectors.
126
+ #
127
+ # See Searchable#css for more information.
128
+ def at_css(*args)
129
+ css(*args).first
130
+ end
131
+
132
+ ###
133
+ # call-seq:
134
+ # xpath(*paths, [namespace-bindings, variable-bindings, custom-handler-class])
135
+ #
136
+ # Search this node for XPath +paths+. +paths+ must be one or more XPath
137
+ # queries.
138
+ #
139
+ # node.xpath('.//title')
140
+ #
141
+ # A hash of namespace bindings may be appended. For example:
142
+ #
143
+ # node.xpath('.//foo:name', {'foo' => 'http://example.org/'})
144
+ # node.xpath('.//xmlns:name', node.root.namespaces)
145
+ #
146
+ # A hash of variable bindings may also be appended to the namespace bindings. For example:
147
+ #
148
+ # node.xpath('.//address[@domestic=$value]', nil, {:value => 'Yes'})
149
+ #
150
+ # Custom XPath functions may also be defined. To define custom
151
+ # functions create a class and implement the function you want
152
+ # to define. The first argument to the method will be the
153
+ # current matching NodeSet. Any other arguments are ones that
154
+ # you pass in. Note that this class may appear anywhere in the
155
+ # argument list. For example:
156
+ #
157
+ # node.xpath('.//title[regex(., "\w+")]', Class.new {
158
+ # def regex node_set, regex
159
+ # node_set.find_all { |node| node['some_attribute'] =~ /#{regex}/ }
160
+ # end
161
+ # }.new)
162
+ #
163
+ def xpath(*args)
164
+ paths, handler, ns, binds = extract_params(args)
165
+
166
+ xpath_internal(self, paths, handler, ns, binds)
167
+ end
168
+
169
+ ##
170
+ # call-seq:
171
+ # at_xpath(*paths, [namespace-bindings, variable-bindings, custom-handler-class])
172
+ #
173
+ # Search this node for XPath +paths+, and return only the first
174
+ # match. +paths+ must be one or more XPath queries.
175
+ #
176
+ # See Searchable#xpath for more information.
177
+ def at_xpath(*args)
178
+ xpath(*args).first
179
+ end
180
+
181
+ # :call-seq:
182
+ # >(selector) → NodeSet
183
+ #
184
+ # Search this node's immediate children using CSS selector +selector+
185
+ def >(selector) # rubocop:disable Naming/BinaryOperatorParameterName
186
+ ns = (document.root&.namespaces || {})
187
+ xpath(CSS.xpath_for(selector, prefix: "./", ns: ns).first)
188
+ end
189
+
190
+ # :section:
191
+
192
+ private
193
+
194
+ def css_internal(node, rules, handler, ns)
195
+ xpath_internal(node, css_rules_to_xpath(rules, ns), handler, ns, nil)
196
+ end
197
+
198
+ def xpath_internal(node, paths, handler, ns, binds)
199
+ document = node.document
200
+ return NodeSet.new(document) unless document
201
+
202
+ if paths.length == 1
203
+ return xpath_impl(node, paths.first, handler, ns, binds)
204
+ end
205
+
206
+ NodeSet.new(document) do |combined|
207
+ paths.each do |path|
208
+ xpath_impl(node, path, handler, ns, binds).each { |set| combined << set }
209
+ end
210
+ end
211
+ end
212
+
213
+ def xpath_impl(node, path, handler, ns, binds)
214
+ ctx = XPathContext.new(node)
215
+ ctx.register_namespaces(ns)
216
+ path = path.gsub(/xmlns:/, " :") unless Nokogiri.uses_libxml?
217
+
218
+ binds&.each do |key, value|
219
+ ctx.register_variable(key.to_s, value)
220
+ end
221
+
222
+ ctx.evaluate(path, handler)
223
+ end
224
+
225
+ def css_rules_to_xpath(rules, ns)
226
+ rules.map { |rule| xpath_query_from_css_rule(rule, ns) }
227
+ end
228
+
229
+ def xpath_query_from_css_rule(rule, ns)
230
+ visitor = Nokogiri::CSS::XPathVisitor.new(
231
+ builtins: Nokogiri::CSS::XPathVisitor::BuiltinsConfig::OPTIMAL,
232
+ doctype: document.xpath_doctype,
233
+ )
234
+ self.class::IMPLIED_XPATH_CONTEXTS.map do |implied_xpath_context|
235
+ CSS.xpath_for(rule.to_s, { prefix: implied_xpath_context, ns: ns,
236
+ visitor: visitor, })
237
+ end.join(" | ")
238
+ end
239
+
240
+ def extract_params(params) # :nodoc:
241
+ handler = params.find do |param|
242
+ ![Hash, String, Symbol].include?(param.class)
243
+ end
244
+ params -= [handler] if handler
245
+
246
+ hashes = []
247
+ while Hash === params.last || params.last.nil?
248
+ hashes << params.pop
249
+ break if params.empty?
250
+ end
251
+ ns, binds = hashes.reverse
252
+
253
+ ns ||= (document.root&.namespaces || {})
254
+
255
+ [params, handler, ns, binds]
256
+ end
257
+ end
258
+ end
259
+ end
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  module Nokogiri
2
4
  module XML
3
5
  ###
@@ -40,7 +42,29 @@ module Nokogiri
40
42
  end
41
43
 
42
44
  def to_s
43
- super.chomp
45
+ message = super.chomp
46
+ [location_to_s, level_to_s, message]
47
+ .compact.join(": ")
48
+ .force_encoding(message.encoding)
49
+ end
50
+
51
+ private
52
+
53
+ def level_to_s
54
+ case level
55
+ when 3 then "FATAL"
56
+ when 2 then "ERROR"
57
+ when 1 then "WARNING"
58
+ end
59
+ end
60
+
61
+ def nil_or_zero?(attribute)
62
+ attribute.nil? || attribute.zero?
63
+ end
64
+
65
+ def location_to_s
66
+ return nil if nil_or_zero?(line) && nil_or_zero?(column)
67
+ "#{line}:#{column}"
44
68
  end
45
69
  end
46
70
  end
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  module Nokogiri
2
4
  module XML
3
5
  class Text < Nokogiri::XML::CharacterData
@@ -1,9 +1,11 @@
1
+ # frozen_string_literal: true
2
+
1
3
  module Nokogiri
2
4
  module XML
3
- class XPath
5
+ module XPath
4
6
  class SyntaxError < XML::SyntaxError
5
7
  def to_s
6
- [super.chomp, str1].compact.join(': ')
8
+ [super.chomp, str1].compact.join(": ")
7
9
  end
8
10
  end
9
11
  end
@@ -1,10 +1,21 @@
1
- require 'nokogiri/xml/xpath/syntax_error'
1
+ # frozen_string_literal: true
2
2
 
3
3
  module Nokogiri
4
4
  module XML
5
- class XPath
6
- # The Nokogiri::XML::Document tied to this XPath instance
7
- attr_accessor :document
5
+ module XPath
6
+ # The XPath search prefix to search globally, +//+
7
+ GLOBAL_SEARCH_PREFIX = "//"
8
+
9
+ # The XPath search prefix to search direct descendants of the root element, +/+
10
+ ROOT_SEARCH_PREFIX = "/"
11
+
12
+ # The XPath search prefix to search direct descendants of the current element, +./+
13
+ CURRENT_SEARCH_PREFIX = "./"
14
+
15
+ # The XPath search prefix to search anywhere in the current element's subtree, +.//+
16
+ SUBTREE_SEARCH_PREFIX = ".//"
8
17
  end
9
18
  end
10
19
  end
20
+
21
+ require_relative "xpath/syntax_error"
@@ -1,16 +1,16 @@
1
+ # frozen_string_literal: true
2
+
1
3
  module Nokogiri
2
4
  module XML
3
5
  class XPathContext
4
-
5
6
  ###
6
7
  # Register namespaces in +namespaces+
7
8
  def register_namespaces(namespaces)
8
9
  namespaces.each do |k, v|
9
- k = k.to_s.gsub(/.*:/,'') # strip off 'xmlns:' or 'xml:'
10
+ k = k.to_s.gsub(/.*:/, "") # strip off 'xmlns:' or 'xml:'
10
11
  register_ns(k, v)
11
12
  end
12
13
  end
13
-
14
14
  end
15
15
  end
16
16
  end
data/lib/nokogiri/xml.rb CHANGED
@@ -1,35 +1,10 @@
1
- require 'nokogiri/xml/pp'
2
- require 'nokogiri/xml/parse_options'
3
- require 'nokogiri/xml/sax'
4
- require 'nokogiri/xml/node'
5
- require 'nokogiri/xml/attribute_decl'
6
- require 'nokogiri/xml/element_decl'
7
- require 'nokogiri/xml/element_content'
8
- require 'nokogiri/xml/character_data'
9
- require 'nokogiri/xml/namespace'
10
- require 'nokogiri/xml/attr'
11
- require 'nokogiri/xml/dtd'
12
- require 'nokogiri/xml/cdata'
13
- require 'nokogiri/xml/text'
14
- require 'nokogiri/xml/document'
15
- require 'nokogiri/xml/document_fragment'
16
- require 'nokogiri/xml/processing_instruction'
17
- require 'nokogiri/xml/node_set'
18
- require 'nokogiri/xml/syntax_error'
19
- require 'nokogiri/xml/xpath'
20
- require 'nokogiri/xml/xpath_context'
21
- require 'nokogiri/xml/builder'
22
- require 'nokogiri/xml/reader'
23
- require 'nokogiri/xml/notation'
24
- require 'nokogiri/xml/entity_decl'
25
- require 'nokogiri/xml/schema'
26
- require 'nokogiri/xml/relax_ng'
1
+ # frozen_string_literal: true
27
2
 
28
3
  module Nokogiri
29
4
  class << self
30
5
  ###
31
6
  # Parse XML. Convenience method for Nokogiri::XML::Document.parse
32
- def XML thing, url = nil, encoding = nil, options = XML::ParseOptions::DEFAULT_XML, &block
7
+ def XML(thing, url = nil, encoding = nil, options = XML::ParseOptions::DEFAULT_XML, &block)
33
8
  Nokogiri::XML::Document.parse(thing, url, encoding, options, &block)
34
9
  end
35
10
  end
@@ -38,20 +13,18 @@ module Nokogiri
38
13
  # Original C14N 1.0 spec canonicalization
39
14
  XML_C14N_1_0 = 0
40
15
  # Exclusive C14N 1.0 spec canonicalization
41
- XML_C14N_EXCLUSIVE_1_0 = 1
16
+ XML_C14N_EXCLUSIVE_1_0 = 1
42
17
  # C14N 1.1 spec canonicalization
43
18
  XML_C14N_1_1 = 2
44
19
  class << self
45
20
  ###
46
21
  # Parse an XML document using the Nokogiri::XML::Reader API. See
47
22
  # Nokogiri::XML::Reader for mor information
48
- def Reader string_or_io, url = nil, encoding = nil, options = ParseOptions::STRICT
49
-
50
- options = Nokogiri::XML::ParseOptions.new(options) if Fixnum === options
51
- # Give the options to the user
23
+ def Reader(string_or_io, url = nil, encoding = nil, options = ParseOptions::STRICT)
24
+ options = Nokogiri::XML::ParseOptions.new(options) if Integer === options
52
25
  yield options if block_given?
53
26
 
54
- if string_or_io.respond_to? :read
27
+ if string_or_io.respond_to?(:read)
55
28
  return Reader.from_io(string_or_io, url, encoding, options.to_i)
56
29
  end
57
30
  Reader.from_memory(string_or_io, url, encoding, options.to_i)
@@ -59,15 +32,44 @@ module Nokogiri
59
32
 
60
33
  ###
61
34
  # Parse XML. Convenience method for Nokogiri::XML::Document.parse
62
- def parse thing, url = nil, encoding = nil, options = ParseOptions::DEFAULT_XML, &block
35
+ def parse(thing, url = nil, encoding = nil, options = ParseOptions::DEFAULT_XML, &block)
63
36
  Document.parse(thing, url, encoding, options, &block)
64
37
  end
65
38
 
66
39
  ####
67
40
  # Parse a fragment from +string+ in to a NodeSet.
68
- def fragment string
69
- XML::DocumentFragment.parse(string)
41
+ def fragment(string, options = ParseOptions::DEFAULT_XML, &block)
42
+ XML::DocumentFragment.parse(string, options, &block)
70
43
  end
71
44
  end
72
45
  end
73
46
  end
47
+
48
+ require_relative "xml/pp"
49
+ require_relative "xml/parse_options"
50
+ require_relative "xml/sax"
51
+ require_relative "xml/searchable"
52
+ require_relative "xml/node"
53
+ require_relative "xml/attribute_decl"
54
+ require_relative "xml/element_decl"
55
+ require_relative "xml/element_content"
56
+ require_relative "xml/character_data"
57
+ require_relative "xml/namespace"
58
+ require_relative "xml/attr"
59
+ require_relative "xml/dtd"
60
+ require_relative "xml/cdata"
61
+ require_relative "xml/text"
62
+ require_relative "xml/document"
63
+ require_relative "xml/document_fragment"
64
+ require_relative "xml/processing_instruction"
65
+ require_relative "xml/node_set"
66
+ require_relative "xml/syntax_error"
67
+ require_relative "xml/xpath"
68
+ require_relative "xml/xpath_context"
69
+ require_relative "xml/builder"
70
+ require_relative "xml/reader"
71
+ require_relative "xml/notation"
72
+ require_relative "xml/entity_decl"
73
+ require_relative "xml/entity_reference"
74
+ require_relative "xml/schema"
75
+ require_relative "xml/relax_ng"
@@ -1,3 +1,5 @@
1
+ # frozen_string_literal: true
2
+
1
3
  module Nokogiri
2
4
  module XSLT
3
5
  ###
@@ -17,7 +19,7 @@ module Nokogiri
17
19
  # Apply an XSLT stylesheet to an XML::Document.
18
20
  # +params+ is an array of strings used as XSLT parameters.
19
21
  # returns serialized document
20
- def apply_to document, params = []
22
+ def apply_to(document, params = [])
21
23
  serialize(transform(document, params))
22
24
  end
23
25
  end
data/lib/nokogiri/xslt.rb CHANGED
@@ -1,4 +1,4 @@
1
- require 'nokogiri/xslt/stylesheet'
1
+ # frozen_string_literal: true
2
2
 
3
3
  module Nokogiri
4
4
  class << self
@@ -9,7 +9,7 @@ module Nokogiri
9
9
  #
10
10
  # xslt = Nokogiri::XSLT(File.read(ARGV[0]))
11
11
  #
12
- def XSLT stylesheet, modules = {}
12
+ def XSLT(stylesheet, modules = {})
13
13
  XSLT.parse(stylesheet, modules)
14
14
  end
15
15
  end
@@ -21,32 +21,32 @@ module Nokogiri
21
21
  class << self
22
22
  ###
23
23
  # Parse the stylesheet in +string+, register any +modules+
24
- def parse string, modules = {}
24
+ def parse(string, modules = {})
25
25
  modules.each do |url, klass|
26
- XSLT.register url, klass
26
+ XSLT.register(url, klass)
27
27
  end
28
28
 
29
+ doc = XML::Document.parse(string, nil, nil, XML::ParseOptions::DEFAULT_XSLT)
29
30
  if Nokogiri.jruby?
30
- Stylesheet.parse_stylesheet_doc(XML.parse(string), string)
31
+ Stylesheet.parse_stylesheet_doc(doc, string)
31
32
  else
32
- Stylesheet.parse_stylesheet_doc(XML.parse(string))
33
+ Stylesheet.parse_stylesheet_doc(doc)
33
34
  end
34
35
  end
35
36
 
36
37
  ###
37
38
  # Quote parameters in +params+ for stylesheet safety
38
- def quote_params params
39
+ def quote_params(params)
39
40
  parray = (params.instance_of?(Hash) ? params.to_a.flatten : params).dup
40
- parray.each_with_index do |v,i|
41
- if i % 2 > 0
42
- parray[i]=
43
- if v =~ /'/
44
- "concat('#{ v.gsub(/'/, %q{', "'", '}) }')"
45
- else
46
- "'#{v}'";
47
- end
41
+ parray.each_with_index do |v, i|
42
+ parray[i] = if i % 2 > 0
43
+ if /'/.match?(v)
44
+ "concat('#{v.gsub(/'/, %q{', "'", '})}')"
45
+ else
46
+ "'#{v}'"
47
+ end
48
48
  else
49
- parray[i] = v.to_s
49
+ v.to_s
50
50
  end
51
51
  end
52
52
  parray.flatten
@@ -54,3 +54,5 @@ module Nokogiri
54
54
  end
55
55
  end
56
56
  end
57
+
58
+ require_relative "xslt/stylesheet"