Module: BuildBox::Config::Options

Included in:
BuildBox::Config
Defined in:
lib/build_box/options/option.rb

Overview

Encapsulates logic for setting options.

Instance Method Summary collapse

Instance Method Details

#defaultsHash

Get the defaults or initialize a new empty hash.

Examples:

Get the defaults.

options.defaults


14
15
16
# File 'lib/build_box/options/option.rb', line 14

def defaults
  @defaults ||= {}
end

#option(name, options = {}) ⇒ Object

Define a configuration option with a default.

Examples:

Define the option.

Options.option(:persist_in_safe_mode, :default => false)

Options Hash (options):

  • :default (Object)

    The default value.



27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
# File 'lib/build_box/options/option.rb', line 27

def option(name, options = {})
  defaults[name] = settings[name] = options[:default]

  class_eval <<-RUBY
    def #{name}
      settings[#{name.inspect}]
    end

    def #{name}=(value)
      settings[#{name.inspect}] = value
    end

    def #{name}?
      #{name}
    end
    
    def reset_#{name}
      settings[#{name.inspect}] = defaults[#{name.inspect}]
    end
  RUBY
end

#resetHash

Reset the configuration options to the defaults.

Examples:

Reset the configuration options.

config.reset


55
56
57
# File 'lib/build_box/options/option.rb', line 55

def reset
  settings.replace(defaults)
end

#settingsHash

Get the settings or initialize a new empty hash.

Examples:

Get the settings.

options.settings


65
66
67
# File 'lib/build_box/options/option.rb', line 65

def settings
  @settings ||= {}
end