Sha256: 5451ea4f3d24c67eab22d65c8d92fb08ffd82ed531be24d5cd30a3d5476b935b

Contents?: true

Size: 1.59 KB

Versions: 62

Compression:

Stored size: 1.59 KB

Contents

# frozen-string-literal: true

require_relative "cache"

class Roda
  # Module in which all Roda plugins should be stored. Also contains logic for
  # registering and loading plugins.
  module RodaPlugins
    OPTS = {}.freeze
    EMPTY_ARRAY = [].freeze

    # Stores registered plugins
    @plugins = RodaCache.new

    class << self
      # Make warn a public method, as it is used for deprecation warnings.
      # Roda::RodaPlugins.warn can be overridden for custom handling of
      # deprecation warnings.
      public :warn
    end

    # If the registered plugin already exists, use it.  Otherwise,
    # require it and return it.  This raises a LoadError if such a
    # plugin doesn't exist, or a RodaError if it exists but it does
    # not register itself correctly.
    def self.load_plugin(name)
      h = @plugins
      unless plugin = h[name]
        require "roda/plugins/#{name}"
        raise RodaError, "Plugin #{name} did not register itself correctly in Roda::RodaPlugins" unless plugin = h[name]
      end
      plugin
    end

    # Register the given plugin with Roda, so that it can be loaded using #plugin
    # with a symbol.  Should be used by plugin files. Example:
    #
    #   Roda::RodaPlugins.register_plugin(:plugin_name, PluginModule)
    def self.register_plugin(name, mod)
      @plugins[name] = mod
    end

    # Deprecate the constant with the given name in the given module,
    # if the ruby version supports it.
    def self.deprecate_constant(mod, name)
      # :nocov:
      if RUBY_VERSION >= '2.3'
        mod.deprecate_constant(name)
      end
      # :nocov:
    end
  end
end

Version data entries

62 entries across 62 versions & 1 rubygems

Version Path
roda-3.88.0 lib/roda/plugins.rb
roda-3.87.0 lib/roda/plugins.rb
roda-3.86.0 lib/roda/plugins.rb
roda-3.85.0 lib/roda/plugins.rb
roda-3.84.0 lib/roda/plugins.rb
roda-3.83.0 lib/roda/plugins.rb
roda-3.82.0 lib/roda/plugins.rb
roda-3.81.0 lib/roda/plugins.rb
roda-3.79.0 lib/roda/plugins.rb
roda-3.78.0 lib/roda/plugins.rb
roda-3.77.0 lib/roda/plugins.rb
roda-3.76.0 lib/roda/plugins.rb
roda-3.75.0 lib/roda/plugins.rb
roda-3.74.0 lib/roda/plugins.rb
roda-3.73.0 lib/roda/plugins.rb
roda-3.72.0 lib/roda/plugins.rb
roda-3.71.0 lib/roda/plugins.rb
roda-3.70.0 lib/roda/plugins.rb
roda-3.69.0 lib/roda/plugins.rb
roda-3.68.0 lib/roda/plugins.rb