summaryrefslogtreecommitdiff
path: root/README.md
blob: 980f551677f63d293f04cf019b1a459fdaf1187e (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
## Mixlib::Config

Mixlib::Config provides a class-based configuration object, as used in Chef.  To use in your project:

  require 'rubygems'
  require 'mixlib/config'

  class MyConfig
    extend(Mixlib::Config)
    configure do |c|
      c[:first_value] = 'something'
      c[:other_value] = 'something_else'
    end
  end

Or...

  class MyConfig
    extend(Mixlib::Config)

    first_value 'something'
    other_value 'something_else'
  end

To check a configuration variable:

  MyConfig.first_value   # returns 'something'
  MyConfig[:first_value] # returns 'something'

To change a configuration variable at runtime:

  MyConfig.first_value('foobar')    # sets first_value to 'foobar'
  MyConfig[:first_value] = 'foobar' # sets first_value to 'foobar'

You should populate your class with the default values for every configuration variable that might be accessed. If you try and access a variable that does not exist, Mixlib::Config will throw an <ArgumentError>.

To load a ruby configuration file (which will evaluate in the context of your configuration class):

  MyConfig.from_file('your_config_file.rb')

Enjoy!