Class: Settingslogic
- Inherits:
-
Hash
- Object
- Hash
- Settingslogic
show all
- Defined in:
- lib/settingslogic.rb
Overview
A simple settings solution using a YAML file. See README for more information.
Defined Under Namespace
Classes: MissingSetting
Class Method Summary
collapse
Instance Method Summary
collapse
Constructor Details
#initialize(hash_or_file = self.class.source, section = nil) ⇒ Settingslogic
Initializes a new settings object. You can initialize an object in any of the following ways:
Settings.new(:application) Settings.new("application.yaml") Settings.new("/var/configs/application.yml") Settings.new(:config1 => 1, :config2 => 2)
Basically if you pass a symbol it will look for that file in the configs directory of your rails app, if you are using this in rails. If you pass a string it should be an absolute path to your settings file. Then you can pass a hash, and it just allows you to access the hash via methods.
90
91
92
93
94
95
96
97
98
99
100
101
102
|
# File 'lib/settingslogic.rb', line 90
def initialize(hash_or_file = self.class.source, section = nil)
case hash_or_file
when Hash
self.replace hash_or_file
else
hash = YAML.load(ERB.new(File.read(hash_or_file)).result).to_hash
default_hash = hash[self.class.default_namespace] || {}
hash = hash[self.class.namespace] if self.class.namespace
self.replace default_hash.deep_merge(hash)
end
@section = section || hash_or_file create_accessors!
end
|
Dynamic Method Handling
This class handles dynamic methods through the method_missing method
#method_missing(key, *args, &block) ⇒ Object
Called for dynamically-defined keys, and also the first key deferenced at the top-level, if load! is not used. Otherwise, create_accessors! (called by new) will have created actual methods for each key.
106
107
108
109
110
111
112
113
|
# File 'lib/settingslogic.rb', line 106
def method_missing(key, *args, &block)
begin
value = fetch(key.to_s)
rescue IndexError
raise MissingSetting, "Missing setting '#{key}' in #{@section}"
end
value.is_a?(Hash) ? self.class.new(value, "'#{key}' section in #{@section}") : value
end
|
Class Method Details
.[](key) ⇒ Object
50
51
52
53
|
# File 'lib/settingslogic.rb', line 50
def [](key)
fetch(key.to_s,nil)
end
|
.[]=(key, val) ⇒ Object
55
56
57
58
|
# File 'lib/settingslogic.rb', line 55
def []=(key,val)
store(key.to_s,val)
end
|
.default_namespace(value = nil) ⇒ Object
29
30
31
32
33
34
35
|
# File 'lib/settingslogic.rb', line 29
def default_namespace(value = nil)
if value.nil?
@default_namespace || 'defaults'
else
@default_namespace = value
end
end
|
.key_by_path(key_path, separator = ".") ⇒ Object
37
38
39
40
41
42
43
44
45
46
47
48
|
# File 'lib/settingslogic.rb', line 37
def key_by_path(key_path, separator = ".")
tmp = instance
key_path.split(separator).each do |k|
if tmp[k].respond_to?("[]") && !tmp[k].nil?
tmp = tmp[k]
else
return nil
end
end
tmp
end
|
.load! ⇒ Object
60
61
62
63
|
# File 'lib/settingslogic.rb', line 60
def load!
instance
true
end
|
.name ⇒ Object
9
10
11
|
# File 'lib/settingslogic.rb', line 9
def name instance.key?("name") ? instance.name : super
end
|
.namespace(value = nil) ⇒ Object
21
22
23
24
25
26
27
|
# File 'lib/settingslogic.rb', line 21
def namespace(value = nil)
if value.nil?
@namespace
else
@namespace = value
end
end
|
.reload! ⇒ Object
65
66
67
68
|
# File 'lib/settingslogic.rb', line 65
def reload!
@instance = nil
load!
end
|
.source(value = nil) ⇒ Object
13
14
15
16
17
18
19
|
# File 'lib/settingslogic.rb', line 13
def source(value = nil)
if value.nil?
@source
else
@source = value
end
end
|