Sha256: 293f47c31793c7fe375f36f99aa7d957cdf8c9f43061638b43ab46c26beb3001
Contents?: true
Size: 1.46 KB
Versions: 1
Compression:
Stored size: 1.46 KB
Contents
require "yaml" require "erb" require "json" require "figgy/version" require "figgy/configuration" require "figgy/hash" require "figgy/finder" require "figgy/store" # An instance of Figgy is the object used to provide access to your # configuration files. This does very little but recognize missing # methods and go look them up as a configuration key. # # To create a new instance, you probably want to use +Figgy.build+: # # MyConfig = Figgy.build do |config| # config.root = '/path/to/my/configs' # end # MyConfig.foo.bar #=> read from /path/to/my/configs/foo.yml # # This should maybe be a BasicObject or similar, to provide as many # available configuration keys as possible. Maybe. class Figgy FileNotFound = Class.new(StandardError) # @yield [Figgy::Configuration] an object to set things up with # @return [Figgy] a Figgy instance using the configuration def self.build(&block) config = Configuration.new block.call(config) new(config) end def initialize(config) @config = config @finder = Finder.new(config) @store = Store.new(@finder, @config) if @config.preload? @finder.all_key_names.each { |key| @store.get(key) } end end def [](key) @store.get(key) end def method_missing(m, *args, &block) @store.get(m) end def inspect if @store.size > 0 key_names = @store.keys.sort "#<Figgy (#{@store.size} keys): #{key_names.join(' ')}>" else "#<Figgy (empty)>" end end end
Version data entries
1 entries across 1 versions & 1 rubygems
Version | Path |
---|---|
figgy-1.0.0 | lib/figgy.rb |