diff options
author | David Heinemeier Hansson <david@loudthinking.com> | 2005-02-20 13:47:57 +0000 |
---|---|---|
committer | David Heinemeier Hansson <david@loudthinking.com> | 2005-02-20 13:47:57 +0000 |
commit | beb2875094d8038b1d5d8fc1a5943884cf96ccf4 (patch) | |
tree | 5e45015a194953e8b96b28f0cbc5e0445491cef1 /activesupport/lib | |
parent | 5fa66cd45c5264080a36d49c9ba803cf2fa3b51b (diff) | |
download | rails-beb2875094d8038b1d5d8fc1a5943884cf96ccf4.tar.gz rails-beb2875094d8038b1d5d8fc1a5943884cf96ccf4.tar.bz2 rails-beb2875094d8038b1d5d8fc1a5943884cf96ccf4.zip |
Updated dependency loading to consider non-standard class/file name combinations
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@712 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
Diffstat (limited to 'activesupport/lib')
-rw-r--r-- | activesupport/lib/active_support/dependencies.rb | 25 |
1 files changed, 21 insertions, 4 deletions
diff --git a/activesupport/lib/active_support/dependencies.rb b/activesupport/lib/active_support/dependencies.rb index 5601893c3d..09fb7cd90c 100644 --- a/activesupport/lib/active_support/dependencies.rb +++ b/activesupport/lib/active_support/dependencies.rb @@ -16,6 +16,7 @@ module Dependencies def depend_on(file_name, swallow_load_errors = false) if !loaded.include?(file_name) loaded << file_name + begin require_or_load(file_name) rescue LoadError @@ -69,11 +70,13 @@ module Dependencies end # Load the controller class or a parent module. - def const_load!(name) - path = self.path + [name] + def const_load!(name, file_name = nil) + path = self.path + [file_name || name] + load_paths.each do |load_path| fs_path = load_path.filesystem_path(path) next unless fs_path + if File.directory?(fs_path) self.const_set name, LoadingModule.new(self.root, self.path + [name]) break @@ -82,6 +85,7 @@ module Dependencies break end end + return self.const_defined?(name) end @@ -94,16 +98,20 @@ module Dependencies class RootLoadingModule < LoadingModule attr_reader :load_paths + def initialize(*paths) @load_paths = paths.flatten.collect {|p| p.kind_of?(ConstantLoadPath) ? p : ConstantLoadPath.new(p)} end + def root() self end + def path() [] end # Load the source file at the given file path def load_file!(file_path) root.module_eval(IO.read(file_path), file_path, 1) end + # Erase all items in this module def clear! constants.each do |name| @@ -123,17 +131,21 @@ module Dependencies def filesystem_path(path, allow_module=true) fs_path = [@root] fs_path += path[0..-2].collect {|name| const_name_to_module_name name} + if allow_module result = File.join(fs_path, const_name_to_module_name(path.last)) return result if File.directory? result # Return the module path if one exists - end + end + result = File.join(fs_path, const_name_to_file_name(path.last)) + return File.file?(result) ? result : nil end def const_name_to_file_name(name) name.to_s.underscore + '.rb' end + def const_name_to_module_name(name) name.to_s.underscore end @@ -152,6 +164,7 @@ class Object #:nodoc: if Object.const_defined?(:Controllers) and Object::Controllers.const_available?(class_id) return Object::Controllers.const_get(class_id) end + begin require_or_load(class_id.to_s.demodulize.underscore) if Object.const_defined?(class_id) then return Object.const_get(class_id) else raise LoadError end @@ -160,6 +173,7 @@ class Object #:nodoc: end end end + def load(file, *extras) begin super(file, *extras) rescue Object => exception @@ -167,6 +181,7 @@ class Object #:nodoc: raise end end + def require(file, *extras) begin super(file, *extras) rescue Object => exception @@ -181,9 +196,11 @@ class Exception def blame_file!(file) (@blamed_files ||= []).unshift file end + attr_reader :blamed_files + def describe_blame return nil if blamed_files.empty? "This error occured while loading the following files:\n #{blamed_files.join '\n '}" end -end +end
\ No newline at end of file |