module Kramdown::Utils::Configurable

Methods for registering configurable extensions.

Public Instance Methods

configurable(name) click to toggle source

Create a new configurable extension called name.

Three methods will be defined on the calling object which allow to use this configurable extension:

configurables

Returns a hash of hashes that is used to store all configurables of the object.

<name>(ext_name)

Return the configured extension ext_name.

add_<name>(ext_name, data=nil, &block)

Define an extension ext_name by specifying either the data as argument or by using a block.

# File lib/kramdown/utils/configurable.rb, line 27
def configurable(name)
  unless respond_to?(:configurables)
    singleton_class.send(:define_method, :configurables) do
      @_configurables ||= Hash.new {|h, k| h[k] = {} }
    end
  end
  singleton_class.send(:define_method, name) do |data|
    configurables[name][data]
  end
  singleton_class.send(:define_method, "add_#{name}".intern) do |data, *args, &block|
    configurables[name][data] = args.first || block
  end
end