nokogiri 1.13.3-x64-mingw-ucrt → 1.13.6-x64-mingw-ucrt
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Potentially problematic release.
This version of nokogiri might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/dependencies.yml +5 -5
- data/ext/nokogiri/extconf.rb +1 -8
- data/ext/nokogiri/html4_sax_parser_context.c +2 -3
- data/ext/nokogiri/include/libxml2/libxml/xmlversion.h +4 -4
- data/ext/nokogiri/xml_sax_parser_context.c +10 -3
- data/lib/nokogiri/3.1/nokogiri.so +0 -0
- data/lib/nokogiri/css/parser_extras.rb +2 -0
- data/lib/nokogiri/html4/document.rb +5 -3
- data/lib/nokogiri/html4/sax/parser.rb +3 -1
- data/lib/nokogiri/html5/document.rb +3 -0
- data/lib/nokogiri/html5/node.rb +4 -0
- data/lib/nokogiri/html5.rb +1 -0
- data/lib/nokogiri/version/constant.rb +1 -1
- data/lib/nokogiri/version/info.rb +1 -0
- data/lib/nokogiri/xml/builder.rb +2 -0
- data/lib/nokogiri/xml/document.rb +5 -0
- data/lib/nokogiri/xml/node/save_options.rb +2 -1
- data/lib/nokogiri/xml/node.rb +9 -3
- data/lib/nokogiri/xml/node_set.rb +4 -0
- data/lib/nokogiri/xml/parse_options.rb +1 -0
- data/lib/nokogiri/xml/processing_instruction.rb +1 -1
- data/lib/nokogiri/xml/sax/parser.rb +1 -0
- data/lib/nokogiri/xml/syntax_error.rb +1 -0
- data/lib/nokogiri/xml.rb +1 -0
- metadata +10 -4
    
        checksums.yaml
    CHANGED
    
    | @@ -1,7 +1,7 @@ | |
| 1 1 | 
             
            ---
         | 
| 2 2 | 
             
            SHA256:
         | 
| 3 | 
            -
              metadata.gz:  | 
| 4 | 
            -
              data.tar.gz:  | 
| 3 | 
            +
              metadata.gz: 4490063504a56aca724735f81da46771f99a94c1dcb63b85483d84037d89498e
         | 
| 4 | 
            +
              data.tar.gz: 1e7331e27e29bdae2fb39a4dc6f3518d2185734d1923d495fad3a251bc29ae52
         | 
| 5 5 | 
             
            SHA512:
         | 
| 6 | 
            -
              metadata.gz:  | 
| 7 | 
            -
              data.tar.gz:  | 
| 6 | 
            +
              metadata.gz: 40d364ca7bd653382fc9434585f04d8410b933f0f3c388bfa0d27a7ec21a38b159168f259cb655a499c3bc7fcfb9ea6fb16832ea9fd06785439642d3f0f50523
         | 
| 7 | 
            +
              data.tar.gz: cd31ef6a451fe7a69f946af617ac07d6c827a9236c9dce19202cdf61be9a8979f7ba15dbeaf947269bc0374fd1c83cc28c19b5905e53670578a37cb80427ef61
         | 
    
        data/dependencies.yml
    CHANGED
    
    | @@ -1,7 +1,7 @@ | |
| 1 1 | 
             
            libxml2:
         | 
| 2 | 
            -
              version: "2.9. | 
| 3 | 
            -
              sha256: " | 
| 4 | 
            -
              # sha-256 hash provided in https://download.gnome.org/sources/libxml2/2.9/libxml2-2.9. | 
| 2 | 
            +
              version: "2.9.14"
         | 
| 3 | 
            +
              sha256: "60d74a257d1ccec0475e749cba2f21559e48139efba6ff28224357c7c798dfee"
         | 
| 4 | 
            +
              # sha-256 hash provided in https://download.gnome.org/sources/libxml2/2.9/libxml2-2.9.14.sha256sum
         | 
| 5 5 |  | 
| 6 6 | 
             
            libxslt:
         | 
| 7 7 | 
             
              version: "1.1.35"
         | 
| @@ -9,8 +9,8 @@ libxslt: | |
| 9 9 | 
             
              # sha-256 hash provided in https://download.gnome.org/sources/libxslt/1.1/libxslt-1.1.35.sha256sum
         | 
| 10 10 |  | 
| 11 11 | 
             
            zlib:
         | 
| 12 | 
            -
              version: "1.2. | 
| 13 | 
            -
              sha256: " | 
| 12 | 
            +
              version: "1.2.12"
         | 
| 13 | 
            +
              sha256: "91844808532e5ce316b3c010929493c0244f3d37593afd6de04f71821d5136d9"
         | 
| 14 14 | 
             
              # SHA-256 hash provided on http://zlib.net/
         | 
| 15 15 |  | 
| 16 16 | 
             
            libiconv:
         | 
    
        data/ext/nokogiri/extconf.rb
    CHANGED
    
    | @@ -382,6 +382,7 @@ def iconv_configure_flags | |
| 382 382 | 
             
              ["iconv", "opt"].each do |target|
         | 
| 383 383 | 
             
                config = preserving_globals { dir_config(target) }
         | 
| 384 384 | 
             
                next unless config.any? && try_link_iconv("--with-#{target}-* flags") { dir_config(target) }
         | 
| 385 | 
            +
             | 
| 385 386 | 
             
                idirs, ldirs = config.map do |dirs|
         | 
| 386 387 | 
             
                  Array(dirs).flat_map do |dir|
         | 
| 387 388 | 
             
                    dir.split(File::PATH_SEPARATOR)
         | 
| @@ -715,14 +716,6 @@ else | |
| 715 716 | 
             
                        execute("configure",
         | 
| 716 717 | 
             
                          ["env", "CHOST=#{host}", "CFLAGS=#{cflags}", "./configure", "--static", configure_prefix])
         | 
| 717 718 | 
             
                      end
         | 
| 718 | 
            -
             | 
| 719 | 
            -
                      def compile
         | 
| 720 | 
            -
                        if /darwin/.match?(host)
         | 
| 721 | 
            -
                          execute("compile", "make AR=#{host}-libtool")
         | 
| 722 | 
            -
                        else
         | 
| 723 | 
            -
                          super
         | 
| 724 | 
            -
                        end
         | 
| 725 | 
            -
                      end
         | 
| 726 719 | 
             
                    end
         | 
| 727 720 | 
             
                  end
         | 
| 728 721 | 
             
                end
         | 
| @@ -19,9 +19,8 @@ parse_memory(VALUE klass, VALUE data, VALUE encoding) | |
| 19 19 | 
             
            {
         | 
| 20 20 | 
             
              htmlParserCtxtPtr ctxt;
         | 
| 21 21 |  | 
| 22 | 
            -
               | 
| 23 | 
            -
             | 
| 24 | 
            -
              }
         | 
| 22 | 
            +
              Check_Type(data, T_STRING);
         | 
| 23 | 
            +
             | 
| 25 24 | 
             
              if (!(int)RSTRING_LEN(data)) {
         | 
| 26 25 | 
             
                rb_raise(rb_eRuntimeError, "data cannot be empty");
         | 
| 27 26 | 
             
              }
         | 
| @@ -29,21 +29,21 @@ XMLPUBFUN void XMLCALL xmlCheckVersion(int version); | |
| 29 29 | 
             
             *
         | 
| 30 30 | 
             
             * the version string like "1.2.3"
         | 
| 31 31 | 
             
             */
         | 
| 32 | 
            -
            #define LIBXML_DOTTED_VERSION "2.9. | 
| 32 | 
            +
            #define LIBXML_DOTTED_VERSION "2.9.14"
         | 
| 33 33 |  | 
| 34 34 | 
             
            /**
         | 
| 35 35 | 
             
             * LIBXML_VERSION:
         | 
| 36 36 | 
             
             *
         | 
| 37 37 | 
             
             * the version number: 1.2.3 value is 10203
         | 
| 38 38 | 
             
             */
         | 
| 39 | 
            -
            #define LIBXML_VERSION  | 
| 39 | 
            +
            #define LIBXML_VERSION 20914
         | 
| 40 40 |  | 
| 41 41 | 
             
            /**
         | 
| 42 42 | 
             
             * LIBXML_VERSION_STRING:
         | 
| 43 43 | 
             
             *
         | 
| 44 44 | 
             
             * the version number string, 1.2.3 value is "10203"
         | 
| 45 45 | 
             
             */
         | 
| 46 | 
            -
            #define LIBXML_VERSION_STRING " | 
| 46 | 
            +
            #define LIBXML_VERSION_STRING "20914"
         | 
| 47 47 |  | 
| 48 48 | 
             
            /**
         | 
| 49 49 | 
             
             * LIBXML_VERSION_EXTRA:
         | 
| @@ -58,7 +58,7 @@ XMLPUBFUN void XMLCALL xmlCheckVersion(int version); | |
| 58 58 | 
             
             * Macro to check that the libxml version in use is compatible with
         | 
| 59 59 | 
             
             * the version the software has been compiled against
         | 
| 60 60 | 
             
             */
         | 
| 61 | 
            -
            #define LIBXML_TEST_VERSION xmlCheckVersion( | 
| 61 | 
            +
            #define LIBXML_TEST_VERSION xmlCheckVersion(20914);
         | 
| 62 62 |  | 
| 63 63 | 
             
            #ifndef VMS
         | 
| 64 64 | 
             
            #if 0
         | 
| @@ -2,6 +2,8 @@ | |
| 2 2 |  | 
| 3 3 | 
             
            VALUE cNokogiriXmlSaxParserContext ;
         | 
| 4 4 |  | 
| 5 | 
            +
            static ID id_read;
         | 
| 6 | 
            +
             | 
| 5 7 | 
             
            static void
         | 
| 6 8 | 
             
            deallocate(xmlParserCtxtPtr ctxt)
         | 
| 7 9 | 
             
            {
         | 
| @@ -26,6 +28,10 @@ parse_io(VALUE klass, VALUE io, VALUE encoding) | |
| 26 28 | 
             
              xmlParserCtxtPtr ctxt;
         | 
| 27 29 | 
             
              xmlCharEncoding enc = (xmlCharEncoding)NUM2INT(encoding);
         | 
| 28 30 |  | 
| 31 | 
            +
              if (!rb_respond_to(io, id_read)) {
         | 
| 32 | 
            +
                rb_raise(rb_eTypeError, "argument expected to respond to :read");
         | 
| 33 | 
            +
              }
         | 
| 34 | 
            +
             | 
| 29 35 | 
             
              ctxt = xmlCreateIOParserCtxt(NULL, NULL,
         | 
| 30 36 | 
             
                                           (xmlInputReadCallback)noko_io_read,
         | 
| 31 37 | 
             
                                           (xmlInputCloseCallback)noko_io_close,
         | 
| @@ -62,9 +68,8 @@ parse_memory(VALUE klass, VALUE data) | |
| 62 68 | 
             
            {
         | 
| 63 69 | 
             
              xmlParserCtxtPtr ctxt;
         | 
| 64 70 |  | 
| 65 | 
            -
               | 
| 66 | 
            -
             | 
| 67 | 
            -
              }
         | 
| 71 | 
            +
              Check_Type(data, T_STRING);
         | 
| 72 | 
            +
             | 
| 68 73 | 
             
              if (!(int)RSTRING_LEN(data)) {
         | 
| 69 74 | 
             
                rb_raise(rb_eRuntimeError, "data cannot be empty");
         | 
| 70 75 | 
             
              }
         | 
| @@ -278,4 +283,6 @@ noko_init_xml_sax_parser_context() | |
| 278 283 | 
             
              rb_define_method(cNokogiriXmlSaxParserContext, "recovery", get_recovery, 0);
         | 
| 279 284 | 
             
              rb_define_method(cNokogiriXmlSaxParserContext, "line", line, 0);
         | 
| 280 285 | 
             
              rb_define_method(cNokogiriXmlSaxParserContext, "column", column, 0);
         | 
| 286 | 
            +
             | 
| 287 | 
            +
              id_read = rb_intern("read");
         | 
| 281 288 | 
             
            }
         | 
| Binary file | 
| @@ -24,12 +24,14 @@ module Nokogiri | |
| 24 24 | 
             
                    # Get the css selector in +string+ from the cache
         | 
| 25 25 | 
             
                    def [](string)
         | 
| 26 26 | 
             
                      return nil unless cache_on?
         | 
| 27 | 
            +
             | 
| 27 28 | 
             
                      @mutex.synchronize { @cache[string] }
         | 
| 28 29 | 
             
                    end
         | 
| 29 30 |  | 
| 30 31 | 
             
                    # Set the css selector in +string+ in the cache to +value+
         | 
| 31 32 | 
             
                    def []=(string, value)
         | 
| 32 33 | 
             
                      return value unless cache_on?
         | 
| 34 | 
            +
             | 
| 33 35 | 
             
                      @mutex.synchronize { @cache[string] = value }
         | 
| 34 36 | 
             
                    end
         | 
| 35 37 |  | 
| @@ -125,8 +125,9 @@ module Nokogiri | |
| 125 125 | 
             
                  private :set_metadata_element
         | 
| 126 126 |  | 
| 127 127 | 
             
                  ####
         | 
| 128 | 
            -
                  # Serialize Node using +options+. | 
| 129 | 
            -
                  # | 
| 128 | 
            +
                  # Serialize Node using +options+. Save options can also be set using a block.
         | 
| 129 | 
            +
                  #
         | 
| 130 | 
            +
                  # See also Nokogiri::XML::Node::SaveOptions and Node@Serialization+and+Generating+Output.
         | 
| 130 131 | 
             
                  #
         | 
| 131 132 | 
             
                  # These two statements are equivalent:
         | 
| 132 133 | 
             
                  #
         | 
| @@ -241,6 +242,7 @@ module Nokogiri | |
| 241 242 |  | 
| 242 243 | 
             
                      def start_element(name, attrs = [])
         | 
| 243 244 | 
             
                        return unless name == "meta"
         | 
| 245 | 
            +
             | 
| 244 246 | 
             
                        attr = Hash[attrs]
         | 
| 245 247 | 
             
                        (charset = attr["charset"]) &&
         | 
| 246 248 | 
             
                          (@encoding = charset)
         | 
| @@ -266,7 +268,7 @@ module Nokogiri | |
| 266 268 | 
             
                    end
         | 
| 267 269 |  | 
| 268 270 | 
             
                    def self.detect_encoding(chunk)
         | 
| 269 | 
            -
                      (m = chunk.match(/\A(<\?xml[ \t\r\n] | 
| 271 | 
            +
                      (m = chunk.match(/\A(<\?xml[ \t\r\n][^>]*>)/)) &&
         | 
| 270 272 | 
             
                        (return Nokogiri.XML(m[1]).encoding)
         | 
| 271 273 |  | 
| 272 274 | 
             
                      if Nokogiri.jruby?
         | 
| @@ -28,8 +28,9 @@ module Nokogiri | |
| 28 28 | 
             
                    ###
         | 
| 29 29 | 
             
                    # Parse html stored in +data+ using +encoding+
         | 
| 30 30 | 
             
                    def parse_memory(data, encoding = "UTF-8")
         | 
| 31 | 
            -
                      raise  | 
| 31 | 
            +
                      raise TypeError unless String === data
         | 
| 32 32 | 
             
                      return if data.empty?
         | 
| 33 | 
            +
             | 
| 33 34 | 
             
                      ctx = ParserContext.memory(data, encoding)
         | 
| 34 35 | 
             
                      yield ctx if block_given?
         | 
| 35 36 | 
             
                      ctx.parse_with(self)
         | 
| @@ -51,6 +52,7 @@ module Nokogiri | |
| 51 52 | 
             
                      raise ArgumentError unless filename
         | 
| 52 53 | 
             
                      raise Errno::ENOENT unless File.exist?(filename)
         | 
| 53 54 | 
             
                      raise Errno::EISDIR if File.directory?(filename)
         | 
| 55 | 
            +
             | 
| 54 56 | 
             
                      ctx = ParserContext.file(filename, encoding)
         | 
| 55 57 | 
             
                      yield ctx if block_given?
         | 
| 56 58 | 
             
                      ctx.parse_with(self)
         | 
| @@ -39,16 +39,19 @@ module Nokogiri | |
| 39 39 | 
             
                    unless string_or_io.respond_to?(:read) || string_or_io.respond_to?(:to_str)
         | 
| 40 40 | 
             
                      raise ArgumentError, "not a string or IO object"
         | 
| 41 41 | 
             
                    end
         | 
| 42 | 
            +
             | 
| 42 43 | 
             
                    do_parse(string_or_io, url, encoding, options)
         | 
| 43 44 | 
             
                  end
         | 
| 44 45 |  | 
| 45 46 | 
             
                  def self.read_io(io, url = nil, encoding = nil, **options)
         | 
| 46 47 | 
             
                    raise ArgumentError, "io object doesn't respond to :read" unless io.respond_to?(:read)
         | 
| 48 | 
            +
             | 
| 47 49 | 
             
                    do_parse(io, url, encoding, options)
         | 
| 48 50 | 
             
                  end
         | 
| 49 51 |  | 
| 50 52 | 
             
                  def self.read_memory(string, url = nil, encoding = nil, **options)
         | 
| 51 53 | 
             
                    raise ArgumentError, "string object doesn't respond to :to_str" unless string.respond_to?(:to_str)
         | 
| 54 | 
            +
             | 
| 52 55 | 
             
                    do_parse(string, url, encoding, options)
         | 
| 53 56 | 
             
                  end
         | 
| 54 57 |  | 
    
        data/lib/nokogiri/html5/node.rb
    CHANGED
    
    | @@ -27,6 +27,7 @@ module Nokogiri | |
| 27 27 | 
             
                module Node
         | 
| 28 28 | 
             
                  def inner_html(options = {})
         | 
| 29 29 | 
             
                    return super(options) unless document.is_a?(HTML5::Document)
         | 
| 30 | 
            +
             | 
| 30 31 | 
             
                    result = options[:preserve_newline] && HTML5.prepend_newline?(self) ? +"\n" : +""
         | 
| 31 32 | 
             
                    result << children.map { |child| child.to_html(options) }.join
         | 
| 32 33 | 
             
                    result
         | 
| @@ -34,6 +35,7 @@ module Nokogiri | |
| 34 35 |  | 
| 35 36 | 
             
                  def write_to(io, *options)
         | 
| 36 37 | 
             
                    return super(io, *options) unless document.is_a?(HTML5::Document)
         | 
| 38 | 
            +
             | 
| 37 39 | 
             
                    options = options.first.is_a?(Hash) ? options.shift : {}
         | 
| 38 40 | 
             
                    encoding = options[:encoding] || options[0]
         | 
| 39 41 | 
             
                    if Nokogiri.jruby?
         | 
| @@ -64,6 +66,7 @@ module Nokogiri | |
| 64 66 |  | 
| 65 67 | 
             
                  def fragment(tags)
         | 
| 66 68 | 
             
                    return super(tags) unless document.is_a?(HTML5::Document)
         | 
| 69 | 
            +
             | 
| 67 70 | 
             
                    DocumentFragment.new(document, tags, self)
         | 
| 68 71 | 
             
                  end
         | 
| 69 72 |  | 
| @@ -76,6 +79,7 @@ module Nokogiri | |
| 76 79 | 
             
                  # actually create the xml namespace if it doesn't exist already.
         | 
| 77 80 | 
             
                  def add_child_node_and_reparent_attrs(node)
         | 
| 78 81 | 
             
                    return super(node) unless document.is_a?(HTML5::Document)
         | 
| 82 | 
            +
             | 
| 79 83 | 
             
                    # I'm not sure what this method is supposed to do. Reparenting
         | 
| 80 84 | 
             
                    # namespaces is handled by libxml2, including child namespaces which
         | 
| 81 85 | 
             
                    # this method wouldn't handle.
         | 
    
        data/lib/nokogiri/html5.rb
    CHANGED
    
    | @@ -468,6 +468,7 @@ module Nokogiri | |
| 468 468 |  | 
| 469 469 | 
             
                def self.prepend_newline?(node)
         | 
| 470 470 | 
             
                  return false unless ["pre", "textarea", "listing"].include?(node.name) && !node.children.empty?
         | 
| 471 | 
            +
             | 
| 471 472 | 
             
                  first_child = node.children[0]
         | 
| 472 473 | 
             
                  first_child.text? && first_child.content.start_with?("\n")
         | 
| 473 474 | 
             
                end
         | 
| @@ -191,6 +191,7 @@ module Nokogiri | |
| 191 191 | 
             
              def self.uses_libxml?(requirement = nil)
         | 
| 192 192 | 
             
                return false unless VersionInfo.instance.libxml2?
         | 
| 193 193 | 
             
                return true unless requirement
         | 
| 194 | 
            +
             | 
| 194 195 | 
             
                Gem::Requirement.new(requirement).satisfied_by?(VersionInfo.instance.loaded_libxml_version)
         | 
| 195 196 | 
             
              end
         | 
| 196 197 |  | 
    
        data/lib/nokogiri/xml/builder.rb
    CHANGED
    
    | @@ -363,6 +363,7 @@ module Nokogiri | |
| 363 363 |  | 
| 364 364 | 
             
                    @parent.ancestors.each do |a|
         | 
| 365 365 | 
             
                      next if a == doc
         | 
| 366 | 
            +
             | 
| 366 367 | 
             
                      @ns = a.namespace_definitions.find { |x| x.prefix == ns.to_s }
         | 
| 367 368 | 
             
                      return self if @ns
         | 
| 368 369 | 
             
                    end
         | 
| @@ -407,6 +408,7 @@ module Nokogiri | |
| 407 408 | 
             
                        if node.namespace.nil?
         | 
| 408 409 | 
             
                          raise ArgumentError, "Namespace #{@ns[:pending]} has not been defined"
         | 
| 409 410 | 
             
                        end
         | 
| 411 | 
            +
             | 
| 410 412 | 
             
                        @ns = nil
         | 
| 411 413 | 
             
                      end
         | 
| 412 414 |  | 
| @@ -321,6 +321,7 @@ module Nokogiri | |
| 321 321 | 
             
                  # the document or +nil+ when there is no DTD.
         | 
| 322 322 | 
             
                  def validate
         | 
| 323 323 | 
             
                    return nil unless internal_subset
         | 
| 324 | 
            +
             | 
| 324 325 | 
             
                    internal_subset.validate(self)
         | 
| 325 326 | 
             
                  end
         | 
| 326 327 |  | 
| @@ -353,8 +354,10 @@ module Nokogiri | |
| 353 354 | 
             
                  # Apply any decorators to +node+
         | 
| 354 355 | 
             
                  def decorate(node)
         | 
| 355 356 | 
             
                    return unless @decorators
         | 
| 357 | 
            +
             | 
| 356 358 | 
             
                    @decorators.each do |klass, list|
         | 
| 357 359 | 
             
                      next unless node.is_a?(klass)
         | 
| 360 | 
            +
             | 
| 358 361 | 
             
                      list.each { |moodule| node.extend(moodule) }
         | 
| 359 362 | 
             
                    end
         | 
| 360 363 | 
             
                  end
         | 
| @@ -380,9 +383,11 @@ module Nokogiri | |
| 380 383 |  | 
| 381 384 | 
             
                  def add_child(node_or_tags)
         | 
| 382 385 | 
             
                    raise "A document may not have multiple root nodes." if (root && root.name != "nokogiri_text_wrapper") && !(node_or_tags.comment? || node_or_tags.processing_instruction?)
         | 
| 386 | 
            +
             | 
| 383 387 | 
             
                    node_or_tags = coerce(node_or_tags)
         | 
| 384 388 | 
             
                    if node_or_tags.is_a?(XML::NodeSet)
         | 
| 385 389 | 
             
                      raise "A document may not have multiple root nodes." if node_or_tags.size > 1
         | 
| 390 | 
            +
             | 
| 386 391 | 
             
                      super(node_or_tags.first)
         | 
| 387 392 | 
             
                    else
         | 
| 388 393 | 
             
                      super
         | 
| @@ -4,7 +4,8 @@ module Nokogiri | |
| 4 4 | 
             
              module XML
         | 
| 5 5 | 
             
                class Node
         | 
| 6 6 | 
             
                  ###
         | 
| 7 | 
            -
                  # Save options for serializing nodes
         | 
| 7 | 
            +
                  # Save options for serializing nodes.
         | 
| 8 | 
            +
                  # See the method group entitled Node@Serialization+and+Generating+Output for usage.
         | 
| 8 9 | 
             
                  class SaveOptions
         | 
| 9 10 | 
             
                    # Format serialized xml
         | 
| 10 11 | 
             
                    FORMAT          = 1
         | 
    
        data/lib/nokogiri/xml/node.rb
    CHANGED
    
    | @@ -124,7 +124,7 @@ module Nokogiri | |
| 124 124 | 
             
                  # [Returns] Nokogiri::XML::Node
         | 
| 125 125 | 
             
                  #
         | 
| 126 126 | 
             
                  def initialize(name, document)
         | 
| 127 | 
            -
                    # This is intentionally empty.
         | 
| 127 | 
            +
                    # This is intentionally empty, and sets the method signature for subclasses.
         | 
| 128 128 | 
             
                  end
         | 
| 129 129 |  | 
| 130 130 | 
             
                  ###
         | 
| @@ -163,6 +163,7 @@ module Nokogiri | |
| 163 163 | 
             
                    if (first = children.first)
         | 
| 164 164 | 
             
                      # Mimic the error add_child would raise.
         | 
| 165 165 | 
             
                      raise "Document already has a root node" if document? && !(node_or_tags.comment? || node_or_tags.processing_instruction?)
         | 
| 166 | 
            +
             | 
| 166 167 | 
             
                      first.__send__(:add_sibling, :previous, node_or_tags)
         | 
| 167 168 | 
             
                    else
         | 
| 168 169 | 
             
                      add_child(node_or_tags)
         | 
| @@ -1072,6 +1073,7 @@ module Nokogiri | |
| 1072 1073 | 
             
                  # nil on XML documents and on unknown tags.
         | 
| 1073 1074 | 
             
                  def description
         | 
| 1074 1075 | 
             
                    return nil if document.xml?
         | 
| 1076 | 
            +
             | 
| 1075 1077 | 
             
                    Nokogiri::HTML4::ElementDescription[name]
         | 
| 1076 1078 | 
             
                  end
         | 
| 1077 1079 |  | 
| @@ -1119,6 +1121,7 @@ module Nokogiri | |
| 1119 1121 |  | 
| 1120 1122 | 
             
                    while parents.last.respond_to?(:parent)
         | 
| 1121 1123 | 
             
                      break unless (ctx_parent = parents.last.parent)
         | 
| 1124 | 
            +
             | 
| 1122 1125 | 
             
                      parents << ctx_parent
         | 
| 1123 1126 | 
             
                    end
         | 
| 1124 1127 |  | 
| @@ -1150,6 +1153,7 @@ module Nokogiri | |
| 1150 1153 | 
             
                  def ==(other)
         | 
| 1151 1154 | 
             
                    return false unless other
         | 
| 1152 1155 | 
             
                    return false unless other.respond_to?(:pointer_id)
         | 
| 1156 | 
            +
             | 
| 1153 1157 | 
             
                    pointer_id == other.pointer_id
         | 
| 1154 1158 | 
             
                  end
         | 
| 1155 1159 |  | 
| @@ -1159,14 +1163,16 @@ module Nokogiri | |
| 1159 1163 | 
             
                  def <=>(other)
         | 
| 1160 1164 | 
             
                    return nil unless other.is_a?(Nokogiri::XML::Node)
         | 
| 1161 1165 | 
             
                    return nil unless document == other.document
         | 
| 1166 | 
            +
             | 
| 1162 1167 | 
             
                    compare(other)
         | 
| 1163 1168 | 
             
                  end
         | 
| 1164 1169 |  | 
| 1165 1170 | 
             
                  # :section: Serialization and Generating Output
         | 
| 1166 1171 |  | 
| 1167 1172 | 
             
                  ###
         | 
| 1168 | 
            -
                  # Serialize Node using +options+. | 
| 1169 | 
            -
                  # | 
| 1173 | 
            +
                  # Serialize Node using +options+. Save options can also be set using a block.
         | 
| 1174 | 
            +
                  #
         | 
| 1175 | 
            +
                  # See also Nokogiri::XML::Node::SaveOptions and Node@Serialization+and+Generating+Output.
         | 
| 1170 1176 | 
             
                  #
         | 
| 1171 1177 | 
             
                  # These two statements are equivalent:
         | 
| 1172 1178 | 
             
                  #
         | 
| @@ -27,6 +27,7 @@ module Nokogiri | |
| 27 27 | 
             
                  # Get the first element of the NodeSet.
         | 
| 28 28 | 
             
                  def first(n = nil)
         | 
| 29 29 | 
             
                    return self[0] unless n
         | 
| 30 | 
            +
             | 
| 30 31 | 
             
                    list = []
         | 
| 31 32 | 
             
                    [n, length].min.times { |i| list << self[i] }
         | 
| 32 33 | 
             
                    list
         | 
| @@ -304,6 +305,7 @@ module Nokogiri | |
| 304 305 | 
             
                  # the set is empty
         | 
| 305 306 | 
             
                  def pop
         | 
| 306 307 | 
             
                    return nil if length == 0
         | 
| 308 | 
            +
             | 
| 307 309 | 
             
                    delete(last)
         | 
| 308 310 | 
             
                  end
         | 
| 309 311 |  | 
| @@ -312,6 +314,7 @@ module Nokogiri | |
| 312 314 | 
             
                  # +nil+ if the set is empty.
         | 
| 313 315 | 
             
                  def shift
         | 
| 314 316 | 
             
                    return nil if length == 0
         | 
| 317 | 
            +
             | 
| 315 318 | 
             
                    delete(first)
         | 
| 316 319 | 
             
                  end
         | 
| 317 320 |  | 
| @@ -322,6 +325,7 @@ module Nokogiri | |
| 322 325 | 
             
                  def ==(other)
         | 
| 323 326 | 
             
                    return false unless other.is_a?(Nokogiri::XML::NodeSet)
         | 
| 324 327 | 
             
                    return false unless length == other.length
         | 
| 328 | 
            +
             | 
| 325 329 | 
             
                    each_with_index do |node, i|
         | 
| 326 330 | 
             
                      return false unless node == other[i]
         | 
| 327 331 | 
             
                    end
         | 
| @@ -101,6 +101,7 @@ module Nokogiri | |
| 101 101 | 
             
                      raise ArgumentError unless filename
         | 
| 102 102 | 
             
                      raise Errno::ENOENT unless File.exist?(filename)
         | 
| 103 103 | 
             
                      raise Errno::EISDIR if File.directory?(filename)
         | 
| 104 | 
            +
             | 
| 104 105 | 
             
                      ctx = ParserContext.file(filename)
         | 
| 105 106 | 
             
                      yield ctx if block_given?
         | 
| 106 107 | 
             
                      ctx.parse_with(self)
         | 
    
        data/lib/nokogiri/xml.rb
    CHANGED
    
    
    
        metadata
    CHANGED
    
    | @@ -1,7 +1,7 @@ | |
| 1 1 | 
             
            --- !ruby/object:Gem::Specification
         | 
| 2 2 | 
             
            name: nokogiri
         | 
| 3 3 | 
             
            version: !ruby/object:Gem::Version
         | 
| 4 | 
            -
              version: 1.13. | 
| 4 | 
            +
              version: 1.13.6
         | 
| 5 5 | 
             
            platform: x64-mingw-ucrt
         | 
| 6 6 | 
             
            authors:
         | 
| 7 7 | 
             
            - Mike Dalessio
         | 
| @@ -20,7 +20,7 @@ authors: | |
| 20 20 | 
             
            autorequire:
         | 
| 21 21 | 
             
            bindir: bin
         | 
| 22 22 | 
             
            cert_chain: []
         | 
| 23 | 
            -
            date: 2022- | 
| 23 | 
            +
            date: 2022-05-08 00:00:00.000000000 Z
         | 
| 24 24 | 
             
            dependencies:
         | 
| 25 25 | 
             
            - !ruby/object:Gem::Dependency
         | 
| 26 26 | 
             
              name: racc
         | 
| @@ -168,14 +168,20 @@ dependencies: | |
| 168 168 | 
             
                requirements:
         | 
| 169 169 | 
             
                - - "~>"
         | 
| 170 170 | 
             
                  - !ruby/object:Gem::Version
         | 
| 171 | 
            -
                    version: '1. | 
| 171 | 
            +
                    version: '1.28'
         | 
| 172 | 
            +
                - - ">="
         | 
| 173 | 
            +
                  - !ruby/object:Gem::Version
         | 
| 174 | 
            +
                    version: 1.28.2
         | 
| 172 175 | 
             
              type: :development
         | 
| 173 176 | 
             
              prerelease: false
         | 
| 174 177 | 
             
              version_requirements: !ruby/object:Gem::Requirement
         | 
| 175 178 | 
             
                requirements:
         | 
| 176 179 | 
             
                - - "~>"
         | 
| 177 180 | 
             
                  - !ruby/object:Gem::Version
         | 
| 178 | 
            -
                    version: '1. | 
| 181 | 
            +
                    version: '1.28'
         | 
| 182 | 
            +
                - - ">="
         | 
| 183 | 
            +
                  - !ruby/object:Gem::Version
         | 
| 184 | 
            +
                    version: 1.28.2
         | 
| 179 185 | 
             
            - !ruby/object:Gem::Dependency
         | 
| 180 186 | 
             
              name: rubocop-minitest
         | 
| 181 187 | 
             
              requirement: !ruby/object:Gem::Requirement
         |