diff options
author | David Heinemeier Hansson <david@loudthinking.com> | 2005-06-27 05:27:35 +0000 |
---|---|---|
committer | David Heinemeier Hansson <david@loudthinking.com> | 2005-06-27 05:27:35 +0000 |
commit | c19b74d9a6776596144b0a2d96e5795785866f40 (patch) | |
tree | 074707f8f320c1877bbd8520de57de0efb80e645 | |
parent | 264a7e7c46339e07be98a9f49db31d83c09e7733 (diff) | |
download | rails-c19b74d9a6776596144b0a2d96e5795785866f40.tar.gz rails-c19b74d9a6776596144b0a2d96e5795785866f40.tar.bz2 rails-c19b74d9a6776596144b0a2d96e5795785866f40.zip |
Dont use evals in backtraces #1513
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@1531 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
-rw-r--r-- | actionpack/lib/action_controller/routing.rb | 14 |
1 files changed, 8 insertions, 6 deletions
diff --git a/actionpack/lib/action_controller/routing.rb b/actionpack/lib/action_controller/routing.rb index 184be83781..fb89d72f20 100644 --- a/actionpack/lib/action_controller/routing.rb +++ b/actionpack/lib/action_controller/routing.rb @@ -217,9 +217,9 @@ module ActionController mod_name = segment.camelize controller_name = "#{mod_name}Controller" - return eval("mod::#{controller_name}"), (index - start_at) if mod.const_available?(controller_name) + return eval("mod::#{controller_name}", nil, 'routing.rb', __LINE__), (index - start_at) if mod.const_available?(controller_name) return nil unless mod.const_available?(mod_name) - mod = eval("mod::#{mod_name}") + mod = eval("mod::#{mod_name}", nil, 'routing.rb', __LINE__) end end end @@ -394,13 +394,15 @@ module ActionController method_name = "generate_path_for_#{ivar}".to_sym instance_variable_set "@#{ivar}", routes code = generation_code_for(ivar, method_name).to_s - eval(code) + + filename = "generated_code/routing/generation_for_controller_#{controller}.rb" + eval(code, nil, filename) @generation_methods[controller.to_s] = method_name @generation_methods[controller.to_sym] = method_name end - eval(generation_code_for('routes', 'generate_default_path').to_s) + eval(generation_code_for('routes', 'generate_default_path').to_s, nil, 'generated_code/routing/generation.rb') end def recognize(request) @@ -434,7 +436,7 @@ module ActionController end end - eval g.to_s + eval g.to_s, nil, 'generated/routing/recognition.rb' end def generation_code_for(ivar = 'routes', method_name = nil) @@ -563,7 +565,7 @@ module ActionController define_method(hash_access_name(name)) { hash } module_eval(%{def #{url_helper_name name}(options = {}) url_for(#{hash_access_name(name)}.merge(options)) - end}) + end}, nil, "generated/routing/named_routes/#{name}.rb") protected url_helper_name(name), hash_access_name(name) |