aboutsummaryrefslogtreecommitdiffstats
path: root/activerecord/lib
diff options
context:
space:
mode:
authorwangjohn <wangjohn@mit.edu>2013-04-09 19:20:49 -0400
committerwangjohn <wangjohn@mit.edu>2013-04-09 22:27:32 -0400
commite12901e4235d1ece2a17c5419f4420f1931cc6a4 (patch)
tree5bcd2ef9f09cc031f54f9475ec28c9f0e6b4c4e1 /activerecord/lib
parent95ac3913ee24efa1c5a9789963697aaa6e5b32b7 (diff)
downloadrails-e12901e4235d1ece2a17c5419f4420f1931cc6a4.tar.gz
rails-e12901e4235d1ece2a17c5419f4420f1931cc6a4.tar.bz2
rails-e12901e4235d1ece2a17c5419f4420f1931cc6a4.zip
Changed the ScopeRegistry and the InstrumentationRegistry to use the
PerThreadRegistry module.
Diffstat (limited to 'activerecord/lib')
-rw-r--r--activerecord/lib/active_record/scoping.rb12
1 files changed, 6 insertions, 6 deletions
diff --git a/activerecord/lib/active_record/scoping.rb b/activerecord/lib/active_record/scoping.rb
index f108ab0fe0..6ab36a23a7 100644
--- a/activerecord/lib/active_record/scoping.rb
+++ b/activerecord/lib/active_record/scoping.rb
@@ -1,3 +1,5 @@
+require 'active_support/per_thread_registry'
+
module ActiveRecord
module Scoping
extend ActiveSupport::Concern
@@ -34,7 +36,7 @@ module ActiveRecord
# to get the current_scope for the +Board+ model, then you would use the
# following code:
#
- # registry = ActiveRecord::Scoping::ScopeRegistry.current
+ # registry = ActiveRecord::Scoping::ScopeRegistry.instance
# registry.set_value_for(:current_scope, "Board", some_new_scope)
#
# Now when you run:
@@ -48,12 +50,10 @@ module ActiveRecord
# ActiveRecord::Scoping::ScopeRegistry.set_value_for(:current_scope,
# "Board", some_new_scope)
class ScopeRegistry # :nodoc:
- class << self
- delegate :value_for, :set_value_for, to: :current
+ extend ActiveSupport::PerThreadRegistry
- def current
- Thread.current["scope_registry"] ||= new
- end
+ class << self
+ delegate :value_for, :set_value_for, to: :instance
end
VALID_SCOPE_TYPES = [:current_scope, :ignore_default_scope]