summaryrefslogtreecommitdiff
path: root/lib/oxidized/manager.rb
diff options
context:
space:
mode:
authorSaku Ytti <saku@ytti.fi>2013-04-17 17:48:50 +0300
committerSaku Ytti <saku@ytti.fi>2013-04-17 17:48:50 +0300
commit9d217025fac3e335c308f02e7377e14ccfdc0e66 (patch)
treeb90d4d04947fe26a9e592e12d8c4352142380c03 /lib/oxidized/manager.rb
Initial commit
Silly for shit-and-giggles attempt at rancid
Diffstat (limited to 'lib/oxidized/manager.rb')
-rw-r--r--lib/oxidized/manager.rb45
1 files changed, 45 insertions, 0 deletions
diff --git a/lib/oxidized/manager.rb b/lib/oxidized/manager.rb
new file mode 100644
index 0000000..0edf9e7
--- /dev/null
+++ b/lib/oxidized/manager.rb
@@ -0,0 +1,45 @@
+module Oxidized
+ require 'oxidized/model/model'
+ require 'oxidized/input/input'
+ require 'oxidized/output/output'
+ require 'oxidized/source/source'
+ class Manager
+ class << self
+ def load dir, file
+ require File.join dir, file+'.rb'
+ obj, Oxidized.mgr.loader = Oxidized.mgr.loader, nil
+ k = obj[:class].new
+ k.setup if k.respond_to? :setup
+ { file => obj[:class] }
+ end
+ end
+ attr_reader :input, :output, :model, :source
+ attr_accessor :loader
+ def initialize
+ @input = {}
+ @output = {}
+ @model = {}
+ @source = {}
+ end
+ def input= method
+ method = Manager.load Config::InputDir, method
+ return false if method.empty?
+ @input.merge! method
+ end
+ def output= method
+ method = Manager.load Config::OutputDir, method
+ return false if method.empty?
+ @output.merge! method
+ end
+ def model= _model
+ _model = Manager.load Config::ModelDir, _model
+ return false if _model.empty?
+ @model.merge! _model
+ end
+ def source= _source
+ _source = Manager.load Config::SourceDir, _source
+ return false if _source.empty?
+ @source.merge! _source
+ end
+ end
+end