summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--lib/oxidized/manager.rb74
1 files changed, 34 insertions, 40 deletions
diff --git a/lib/oxidized/manager.rb b/lib/oxidized/manager.rb
index c4523f3..e4a1d7c 100644
--- a/lib/oxidized/manager.rb
+++ b/lib/oxidized/manager.rb
@@ -6,23 +6,20 @@ module Oxidized
class Manager
class << self
def load dir, file
- begin
- require File.join dir, file + '.rb'
- klass = nil
- [Oxidized, Object].each do |mod|
- klass = mod.constants.find { |const| const.to_s.downcase == file.downcase }
- klass = mod.constants.find { |const| const.to_s.downcase == 'oxidized' + file.downcase } unless klass
- klass = mod.const_get klass if klass
- break if klass
- end
- i = klass.new
- i.setup if i.respond_to? :setup
- { file => klass }
- rescue LoadError
- {}
+ require File.join dir, file + '.rb'
+ klass = nil
+ [Oxidized, Object].each do |mod|
+ klass = mod.constants.find { |const| const.to_s.downcase == file.downcase }
+ klass = mod.constants.find { |const| const.to_s.downcase == 'oxidized' + file.downcase } unless klass
+ klass = mod.const_get klass if klass
+ break if klass
end
+ i = klass.new
+ i.setup if i.respond_to? :setup
+ { file => klass }
end
end
+
attr_reader :input, :output, :model, :source, :hook
def initialize
@input = {}
@@ -32,40 +29,37 @@ module Oxidized
@hook = {}
end
- def add_input method
- method = Manager.load Config::InputDir, method
- return false if method.empty?
- @input.merge! method
+ def add_input name
+ @input.merge! Manager.load(Config::InputDir, name)
+ end
+
+ def add_output name
+ @output.merge! Manager.load(Config::OutputDir, name)
end
- def add_output method
- method = Manager.load Config::OutputDir, method
- return false if method.empty?
- @output.merge! method
+ def add_source name
+ return nil if @source.has_key? name
+ @source.merge Manager.load(Config::SourceDir, name)
end
- def add_model _model
- name = _model
- _model = Manager.load File.join(Config::Root, 'model'), name
- _model = Manager.load Config::ModelDir, name if _model.empty?
- return false if _model.empty?
- @model.merge! _model
+ def add_model name
+ @model.merge! local_load("model", name) ||
+ Manager.load(Config::ModelDir, name)
end
- def add_source _source
- return nil if @source.has_key? _source
- _source = Manager.load Config::SourceDir, _source
- return false if _source.empty?
- @source.merge! _source
+ def add_hook name
+ return nil if @hook.has_key? name
+ @model.merge! local_load("hook", name) ||
+ Manager.load(Config::HookDir, name)
end
- def add_hook _hook
- return nil if @hook.has_key? _hook
- name = _hook
- _hook = Manager.load File.join(Config::Root, 'hook'), name
- _hook = Manager.load Config::HookDir, name if _hook.empty?
- return false if _hook.empty?
- @hook.merge! _hook
+ private
+
+ # try to load locally defined file, instead of upstream provided
+ def local_load dir, file
+ dir = File.join(Config::Root, dir)
+ return false unless File.exist? File.join(dir, file)
+ Manager.load dir, file
end
end
end