diff options
author | Aaron Patterson <aaron.patterson@gmail.com> | 2011-07-29 14:38:57 -0700 |
---|---|---|
committer | Aaron Patterson <aaron.patterson@gmail.com> | 2011-07-29 14:38:57 -0700 |
commit | ea7f50863d3a1e58a28921b15da3927ad7d18f4a (patch) | |
tree | 2db67a5e4ec1e56e9bb1774f8b46f77a2cf2b4d9 | |
parent | cea06a8e3f1f129ef330b346a38571a8a3309812 (diff) | |
download | rails-ea7f50863d3a1e58a28921b15da3927ad7d18f4a.tar.gz rails-ea7f50863d3a1e58a28921b15da3927ad7d18f4a.tar.bz2 rails-ea7f50863d3a1e58a28921b15da3927ad7d18f4a.zip |
delay backtrace scrubbing until we actually raise an exception. fixes #1936
-rw-r--r-- | activesupport/lib/active_support/dependencies.rb | 11 |
1 files changed, 4 insertions, 7 deletions
diff --git a/activesupport/lib/active_support/dependencies.rb b/activesupport/lib/active_support/dependencies.rb index 8cd4d15e4c..3f6c93e860 100644 --- a/activesupport/lib/active_support/dependencies.rb +++ b/activesupport/lib/active_support/dependencies.rb @@ -478,10 +478,6 @@ module ActiveSupport #:nodoc: qualified_name = qualified_name_for from_mod, const_name path_suffix = qualified_name.underscore - trace = caller.reject {|l| l.starts_with? __FILE__ } - name_error = NameError.new("uninitialized constant #{qualified_name}") - name_error.set_backtrace(trace) - file_path = search_for_file(path_suffix) if file_path && ! loaded.include?(File.expand_path(file_path)) # We found a matching file to load @@ -500,11 +496,12 @@ module ActiveSupport #:nodoc: return parent.const_missing(const_name) rescue NameError => e raise unless e.missing_name? qualified_name_for(parent, const_name) - raise name_error end - else - raise name_error end + + raise NameError, + "uninitialized constant #{qualified_name}", + caller.reject {|l| l.starts_with? __FILE__ } end # Remove the constants that have been autoloaded, and those that have been |