Sha256: 29193dcae598b86ca2a0ae20ff16b128cbed7892e05a5e07de53f47c1badd3c6

Contents?: true

Size: 1.98 KB

Versions: 370

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"])

    # :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

370 entries across 368 versions & 10 rubygems

Version Path
nokogiri-1.16.1-arm64-darwin lib/nokogiri/class_resolver.rb
nokogiri-1.16.1-arm-linux lib/nokogiri/class_resolver.rb
nokogiri-1.16.1-aarch64-linux lib/nokogiri/class_resolver.rb
getargv-0.3.3-universal-darwin vendor/bundle/ruby/3.3.0/gems/nokogiri-1.16.0-x86_64-darwin/lib/nokogiri/class_resolver.rb
nokogiri-1.16.0 lib/nokogiri/class_resolver.rb
nokogiri-1.16.0-x86_64-linux lib/nokogiri/class_resolver.rb
nokogiri-1.16.0-x86_64-darwin lib/nokogiri/class_resolver.rb
nokogiri-1.16.0-x86-mingw32 lib/nokogiri/class_resolver.rb
nokogiri-1.16.0-x86-linux lib/nokogiri/class_resolver.rb
nokogiri-1.16.0-x64-mingw32 lib/nokogiri/class_resolver.rb
nokogiri-1.16.0-x64-mingw-ucrt lib/nokogiri/class_resolver.rb
nokogiri-1.16.0-java lib/nokogiri/class_resolver.rb
nokogiri-1.16.0-arm64-darwin lib/nokogiri/class_resolver.rb
nokogiri-1.16.0-arm-linux lib/nokogiri/class_resolver.rb
nokogiri-1.16.0-aarch64-linux lib/nokogiri/class_resolver.rb
nokogiri-1.16.0.rc1 lib/nokogiri/class_resolver.rb
nokogiri-1.16.0.rc1-x86_64-linux lib/nokogiri/class_resolver.rb
nokogiri-1.16.0.rc1-x86_64-darwin lib/nokogiri/class_resolver.rb
nokogiri-1.16.0.rc1-x86-mingw32 lib/nokogiri/class_resolver.rb
nokogiri-1.16.0.rc1-x86-linux lib/nokogiri/class_resolver.rb