Class: Webgen::Task
- Inherits:
-
Object
- Object
- Webgen::Task
- Includes:
- ExtensionManager
- Defined in:
- lib/webgen/task.rb,
lib/webgen/task/create_bundle.rb,
lib/webgen/task/create_website.rb,
lib/webgen/task/generate_website.rb
Overview
Namespace for all tasks.
About
Tasks provide the main entrance point for doing things with a website, like creating it, generating it, and much more.
Implementing a task
A task object only needs to respond to one method called call
which takes the website as first parameter and may take an arbitrary number of additional arguments. The method should return true
if the task was executed sucessfully or else false
.
Due to this there are basically two ways to implement a task since: Either as a class with a class method called call
. Or as a Proc object.
If the task needs to be configured to work correctly, use additional parameters or configuration options.
The task has to be registered so that webgen knows about it, see #register for more information.
Sample Task
The following sample task just outputs the value of its configuration option:
class OutputTask
def self.call(website, )
website.logger.vinfo("The output task configuration value follows")
website.logger.info(website.config['task.output.option'])
true
end
end
website.config.define_option('task.output.option', nil, 'The configuration option')
website.ext.task.register OutputTask, :name => 'output'
Defined Under Namespace
Modules: CreateBundle, CreateWebsite, GenerateWebsite
Instance Method Summary collapse
-
#data(name) ⇒ Object
Return the task data for the given task.
-
#execute(name, *options) ⇒ Object
Execute the task identified by the given name.
-
#initialize(website) ⇒ Task
constructor
Create a new task manager for the given website.
-
#register(klass, options = {}, &block) ⇒ Object
Register a task.
Methods included from ExtensionManager
#initialize_copy, #registered?, #registered_extensions
Constructor Details
#initialize(website) ⇒ Task
Create a new task manager for the given website.
50 51 52 53 |
# File 'lib/webgen/task.rb', line 50 def initialize(website) super() @website = website end |
Instance Method Details
#data(name) ⇒ Object
Return the task data for the given task.
93 94 95 |
# File 'lib/webgen/task.rb', line 93 def data(name) ext_data(name).data end |
#execute(name, *options) ⇒ Object
Execute the task identified by the given name.
88 89 90 |
# File 'lib/webgen/task.rb', line 88 def execute(name, *) extension(name).call(@website, *) end |
#register(klass, options = {}, &block) ⇒ Object
Register a task.
The parameter klass
can either be a String containing the name of a class/module (which has to respond to :call) or an object that responds to :call. If the class is located under this namespace, only the class name without the hierarchy part is needed, otherwise the full class/module name including parent module/class names is needed.
Instead of registering an object that responds to :call, you can also provide a block.
Options:
- :name
-
The name for the task. If not set, it defaults to the snake-case version of the class name (without the hierarchy part). It should only contain letters.
- :data
-
Associates arbitrary data with the task object. This data can be retrieved using the #data method.
Examples:
task.register('CreateWebsite') # registers Webgen::Task::CreateWebsite
task.register('::CreateWebsite') # registers CreateWebsite !!!
task.register('doit') do |website|
# task commands go here
end
82 83 84 85 |
# File 'lib/webgen/task.rb', line 82 def register(klass, ={}, &block) name = do_register(klass, , true, &block) ext_data(name).data = [:data] end |