aboutsummaryrefslogtreecommitdiffstats
path: root/lib/arel
diff options
context:
space:
mode:
authorGarrett Thornburg <film42@gmail.com>2017-02-17 11:40:29 -0700
committerGarrett Thornburg <film42@gmail.com>2017-02-17 11:40:29 -0700
commitdba166bfd317bfeaba7211d2e65fbd760a184f6c (patch)
treef670b14e0f7eeed2da8e2ac83da4c66424ae878e /lib/arel
parent208fe3690d840d0ee65b1395a891886e58fd3f4b (diff)
downloadrails-dba166bfd317bfeaba7211d2e65fbd760a184f6c.tar.gz
rails-dba166bfd317bfeaba7211d2e65fbd760a184f6c.tar.bz2
rails-dba166bfd317bfeaba7211d2e65fbd760a184f6c.zip
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)
}