Sha256: eaa3084bb143ec57af54f653cf73f8b892ba8254155cb23ebb24f3a26e7fff5b

Contents?: true

Size: 1.91 KB

Versions: 10

Compression:

Stored size: 1.91 KB

Contents

module Jekyll

  class Plugin
    PRIORITIES = { :lowest => -100,
                   :low => -10,
                   :normal => 0,
                   :high => 10,
                   :highest => 100 }

    # Install a hook so that subclasses are recorded. This method is only
    # ever called by Ruby itself.
    #
    # base - The Class subclass.
    #
    # Returns nothing.
    def self.inherited(base)
      subclasses << base
      subclasses.sort!
    end

    # The list of Classes that have been subclassed.
    #
    # Returns an Array of Class objects.
    def self.subclasses
      @subclasses ||= []
    end

    # Get or set the priority of this plugin. When called without an
    # argument it returns the priority. When an argument is given, it will
    # set the priority.
    #
    # priority - The Symbol priority (default: nil). Valid options are:
    #            :lowest, :low, :normal, :high, :highest
    #
    # Returns the Symbol priority.
    def self.priority(priority = nil)
      if priority && PRIORITIES.has_key?(priority)
        @priority = priority
      end
      @priority || :normal
    end

    # Get or set the safety of this plugin. When called without an argument
    # it returns the safety. When an argument is given, it will set the
    # safety.
    #
    # safe - The Boolean safety (default: nil).
    #
    # Returns the safety Boolean.
    def self.safe(safe = nil)
      if safe
        @safe = safe
      end
      @safe || false
    end

    # Spaceship is priority [higher -> lower]
    #
    # other - The class to be compared.
    #
    # Returns -1, 0, 1.
    def self.<=>(other)
      PRIORITIES[other.priority] <=> PRIORITIES[self.priority]
    end

    # Initialize a new plugin. This should be overridden by the subclass.
    #
    # config - The Hash of configuration options.
    #
    # Returns a new instance.
    def initialize(config = {})
      # no-op for default
    end
  end

end

Version data entries

10 entries across 10 versions & 4 rubygems

Version Path
fagiani-jekyll-0.10.1 lib/jekyll/plugin.rb
jekyll-0.10.0 lib/jekyll/plugin.rb
jekyll-0.9.0 lib/jekyll/plugin.rb
jekyll-0.8.0 lib/jekyll/plugin.rb
realityforge-jekyll-0.7.1-java lib/jekyll/plugin.rb
jekyll-0.7.0 lib/jekyll/plugin.rb
cartera-jekyll-0.6.2 lib/jekyll/plugin.rb
jekyll-0.6.2 lib/jekyll/plugin.rb
jekyll-0.6.1 lib/jekyll/plugin.rb
jekyll-0.6.0 lib/jekyll/plugin.rb