From 9d217025fac3e335c308f02e7377e14ccfdc0e66 Mon Sep 17 00:00:00 2001 From: Saku Ytti Date: Wed, 17 Apr 2013 17:48:50 +0300 Subject: Initial commit Silly for shit-and-giggles attempt at rancid --- lib/oxidized/manager.rb | 45 +++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 45 insertions(+) create mode 100644 lib/oxidized/manager.rb (limited to 'lib/oxidized/manager.rb') 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 -- cgit v1.2.1