aboutsummaryrefslogtreecommitdiffstats
path: root/lib/arel
diff options
context:
space:
mode:
authorMatthew Draper <matthew@trebex.net>2017-06-05 06:32:42 +0930
committerGitHub <noreply@github.com>2017-06-05 06:32:42 +0930
commitde0a83e11cae11ba0674bd197296326e53354597 (patch)
treef2fc8b94904a06e13e4442287541ed48100a64c9 /lib/arel
parent03a2de4d063f52250105c08c0c05d64c5d42561d (diff)
parentf509ad3c72ed55d9fb35848664a771815aa4599b (diff)
downloadrails-de0a83e11cae11ba0674bd197296326e53354597.tar.gz
rails-de0a83e11cae11ba0674bd197296326e53354597.tar.bz2
rails-de0a83e11cae11ba0674bd197296326e53354597.zip
Merge pull request #472 from film42/master
Make Visitor visit thread safe by holding dispatch method reference
Diffstat (limited to 'lib/arel')
-rw-r--r--lib/arel/visitors/reduce.rb5
-rw-r--r--lib/arel/visitors/visitor.rb5
2 files changed, 6 insertions, 4 deletions
diff --git a/lib/arel/visitors/reduce.rb b/lib/arel/visitors/reduce.rb
index 7948758e2f..1156b780f0 100644
--- a/lib/arel/visitors/reduce.rb
+++ b/lib/arel/visitors/reduce.rb
@@ -11,9 +11,10 @@ module Arel
private
def visit object, collector
- send dispatch[object.class], object, collector
+ dispatch_method = dispatch[object.class]
+ send dispatch_method, object, collector
rescue NoMethodError => e
- raise e if respond_to?(dispatch[object.class], true)
+ raise e if respond_to?(dispatch_method, true)
superklass = object.class.ancestors.find { |klass|
respond_to?(dispatch[klass], true)
}
diff --git a/lib/arel/visitors/visitor.rb b/lib/arel/visitors/visitor.rb
index b96b8238a7..2690c98e3c 100644
--- a/lib/arel/visitors/visitor.rb
+++ b/lib/arel/visitors/visitor.rb
@@ -27,9 +27,10 @@ module Arel
end
def visit object
- send dispatch[object.class], object
+ dispatch_method = dispatch[object.class]
+ send dispatch_method, object
rescue NoMethodError => e
- raise e if respond_to?(dispatch[object.class], true)
+ raise e if respond_to?(dispatch_method, true)
superklass = object.class.ancestors.find { |klass|
respond_to?(dispatch[klass], true)
}