aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAaron Patterson <aaron.patterson@gmail.com>2011-07-29 14:38:57 -0700
committerAaron Patterson <aaron.patterson@gmail.com>2011-07-29 14:38:57 -0700
commitea7f50863d3a1e58a28921b15da3927ad7d18f4a (patch)
tree2db67a5e4ec1e56e9bb1774f8b46f77a2cf2b4d9
parentcea06a8e3f1f129ef330b346a38571a8a3309812 (diff)
downloadrails-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.rb11
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