Sha256: 8f185a62f30827f535598078ffe5450391145e3e50efa1026f5869b9832654a6

Contents?: true

Size: 1.98 KB

Versions: 111

Compression:

Stored size: 1.98 KB

Contents

# coding: utf-8
# frozen_string_literal: true

require "set"

module Nokogiri
  #
  # Some classes in Nokogiri are namespaced as a group, for example
  # Document, DocumentFragment, and Builder.
  #
  # It's sometimes necessary to look up the related class, e.g.:
  #
  #   XML::Builder → XML::Document
  #   HTML4::Builder → HTML4::Document
  #   HTML5::Document → HTML5::DocumentFragment
  #
  # This module is included into those key classes who need to do this.
  #
  module ClassResolver
    # #related_class restricts matching namespaces to those matching this set.
    VALID_NAMESPACES = Set.new(["HTML", "HTML4", "HTML5", "XML", "SAX"])

    # :call-seq:
    #   related_class(class_name) → Class
    #
    # Find a class constant within the
    #
    # Some examples:
    #
    #   Nokogiri::XML::Document.new.related_class("DocumentFragment")
    #   # => Nokogiri::XML::DocumentFragment
    #   Nokogiri::HTML4::Document.new.related_class("DocumentFragment")
    #   # => Nokogiri::HTML4::DocumentFragment
    #
    # Note this will also work for subclasses that follow the same convention, e.g.:
    #
    #   Loofah::HTML::Document.new.related_class("DocumentFragment")
    #   # => Loofah::HTML::DocumentFragment
    #
    # And even if it's a subclass, this will iterate through the superclasses:
    #
    #   class ThisIsATopLevelClass < Nokogiri::HTML4::Builder ; end
    #   ThisIsATopLevelClass.new.related_class("Document")
    #   # => Nokogiri::HTML4::Document
    #
    def related_class(class_name)
      klass = nil
      inspecting = self.class

      while inspecting
        namespace_path = inspecting.name.split("::")[0..-2]
        inspecting = inspecting.superclass

        next unless VALID_NAMESPACES.include?(namespace_path.last)

        related_class_name = (namespace_path << class_name).join("::")
        klass = begin
          Object.const_get(related_class_name)
        rescue NameError
          nil
        end
        break if klass
      end
      klass
    end
  end
end

Version data entries

111 entries across 111 versions & 2 rubygems

Version Path
nokogiri-1.18.5-x86_64-linux-musl lib/nokogiri/class_resolver.rb
nokogiri-1.18.5-x86_64-linux-gnu lib/nokogiri/class_resolver.rb
nokogiri-1.18.5-x86_64-darwin lib/nokogiri/class_resolver.rb
nokogiri-1.18.5-x64-mingw-ucrt lib/nokogiri/class_resolver.rb
nokogiri-1.18.5-java lib/nokogiri/class_resolver.rb
nokogiri-1.18.5 lib/nokogiri/class_resolver.rb
nokogiri-1.18.5-arm-linux-musl lib/nokogiri/class_resolver.rb
nokogiri-1.18.5-arm-linux-gnu lib/nokogiri/class_resolver.rb
nokogiri-1.18.5-arm64-darwin lib/nokogiri/class_resolver.rb
nokogiri-1.18.5-aarch64-linux-musl lib/nokogiri/class_resolver.rb
nokogiri-1.18.5-aarch64-linux-gnu lib/nokogiri/class_resolver.rb
nokogiri-1.18.4-x86_64-linux-musl lib/nokogiri/class_resolver.rb
nokogiri-1.18.4-x86_64-linux-gnu lib/nokogiri/class_resolver.rb
nokogiri-1.18.4-x86_64-darwin lib/nokogiri/class_resolver.rb
nokogiri-1.18.4-x64-mingw-ucrt lib/nokogiri/class_resolver.rb
nokogiri-1.18.4-java lib/nokogiri/class_resolver.rb
nokogiri-1.18.4 lib/nokogiri/class_resolver.rb
nokogiri-1.18.4-arm-linux-musl lib/nokogiri/class_resolver.rb
nokogiri-1.18.4-arm-linux-gnu lib/nokogiri/class_resolver.rb
nokogiri-1.18.4-arm64-darwin lib/nokogiri/class_resolver.rb