diff options
author | Rafael Mendonça França <rafaelmfranca@gmail.com> | 2013-05-14 11:39:18 -0700 |
---|---|---|
committer | Rafael Mendonça França <rafaelmfranca@gmail.com> | 2013-05-14 11:39:18 -0700 |
commit | 8ce3c1e5dde9fb180813e4d89324db03da110b13 (patch) | |
tree | 77614c534d23a6187f1e2dc3fcbc2805ccd9377f | |
parent | f93da579ce7f77dbd58b9a2165861aee265b8c93 (diff) | |
parent | 426f42c09287c218466ccb060552a8717be0513f (diff) | |
download | rails-8ce3c1e5dde9fb180813e4d89324db03da110b13.tar.gz rails-8ce3c1e5dde9fb180813e4d89324db03da110b13.tar.bz2 rails-8ce3c1e5dde9fb180813e4d89324db03da110b13.zip |
Merge pull request #10600 from aditya-kapoor/code_refactor
Removed Class Eval and used define_method instead for the SafeBuffer
-rw-r--r-- | activesupport/lib/active_support/core_ext/string/output_safety.rb | 20 |
1 files changed, 9 insertions, 11 deletions
diff --git a/activesupport/lib/active_support/core_ext/string/output_safety.rb b/activesupport/lib/active_support/core_ext/string/output_safety.rb index dc033ed11b..7c21abea72 100644 --- a/activesupport/lib/active_support/core_ext/string/output_safety.rb +++ b/activesupport/lib/active_support/core_ext/string/output_safety.rb @@ -171,17 +171,15 @@ module ActiveSupport #:nodoc: end UNSAFE_STRING_METHODS.each do |unsafe_method| - if 'String'.respond_to?(unsafe_method) - class_eval <<-EOT, __FILE__, __LINE__ + 1 - def #{unsafe_method}(*args, &block) # def capitalize(*args, &block) - to_str.#{unsafe_method}(*args, &block) # to_str.capitalize(*args, &block) - end # end - - def #{unsafe_method}!(*args) # def capitalize!(*args) - @html_safe = false # @html_safe = false - super # super - end # end - EOT + if String.new.respond_to?(unsafe_method) + define_method(unsafe_method) do |*args, &block| + to_str.send(unsafe_method, *args, &block) + end + + define_method("#{unsafe_method}!") do |*args| + @html_safe = false + super(*args) + end end end end |