Module: Doing::Plugins

Defined in:
lib/doing/plugin_manager.rb

Overview

Plugin handling

Class Method Summary collapse

Class Method Details

.available_plugins(type: :export) ⇒ Array<String>

Return array of available plugin names

Parameters:

  • type (defaults to: :export)

    Plugin type (:import, :export)

Returns:

.list_plugins(options = {}) ⇒ Object

List available plugins to stdout

Parameters:

  • options (type, separator) (defaults to: {})

.load_plugins(add_dir = nil) ⇒ Object

Load plugins from plugins folder

.plugin_names(type: :export, separator: '|') ⇒ String

Return string version of plugin names

Parameters:

  • type (defaults to: :export)

    Plugin type (:import, :export)

  • separator (defaults to: '|')

    The separator to join names with

Returns:

.plugin_regex(type: :export) ⇒ Regexp

Return a regular expression of all plugin triggers for type

Parameters:

  • type (Symbol) (defaults to: :export)

    The type :import or :export

Returns:

  • (Regexp)

    regular expression

.plugin_templates(type: :export) ⇒ Array<String>

Return array of available template names

Parameters:

  • type (Symbol) (defaults to: :export)

    Plugin type (:import, :export)

Returns:

.pluginsObject

.plugins_path(add_dir = nil) ⇒ Array

Setup the plugin search path

Parameters:

  • add_dir (String) (defaults to: nil)

    optional additional path to include

Returns:

  • (Array)

    Returns an Array of plugin search paths

.register(title, type, klass) ⇒ Boolean

Register a plugin

Parameters:

  • title (String|Array)

    The name of the plugin (can be an array of names)

  • type (Symbol)

    The plugin type (:import, :export)

  • klass (Class)

    The class responding to :render or :import

Returns:

  • (Boolean)

    Success boolean

.save_template(tpl, dir, filename) ⇒ Object

Raises:

  • (DoingRuntimeError)

.template_for_trigger(trigger, type: :export, save_to: nil) ⇒ String

Find and return the appropriate template for a trigger string. Outputs a string that can be written out to the terminal for redirection

Parameters:

  • trigger (String)

    The trigger to test

  • type (Symbol) (defaults to: :export)

    the plugin type (:import, :export)

Returns:

  • (String)

    string content of template for trigger

Raises:

.template_regex(type: :export) ⇒ Regexp

Return a regular expression of all template triggers for type

Parameters:

  • type (Symbol) (defaults to: :export)

    The type :import or :export

Returns:

  • (Regexp)

    regular expression

.user_homeObject

.valid_type(type, default: nil) ⇒ Symbol

Converts a partial symbol to a valid plugin type, e.g. :imp => :import

Parameters:

  • type (Symbol)

    the symbol to test

  • default (Symbol) (defaults to: nil)

    fallback value

Returns:

  • (Symbol)

    :import or :export

.validate_plugin(title, type, klass) ⇒ Object