aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJeremy Kemper <jeremy@bitsweat.net>2010-06-05 20:34:30 -0700
committerJeremy Kemper <jeremy@bitsweat.net>2010-06-05 22:09:16 -0700
commit509f3d7d2f346b83dfd22aec681feffbd2d25803 (patch)
treeb5d1d7c848fdcceaeba8e0b70bfd11d9c60a1fa6
parent9d0d6f7d261a14def6afd17568b8c8aa7c33d0b3 (diff)
downloadrails-509f3d7d2f346b83dfd22aec681feffbd2d25803.tar.gz
rails-509f3d7d2f346b83dfd22aec681feffbd2d25803.tar.bz2
rails-509f3d7d2f346b83dfd22aec681feffbd2d25803.zip
Simplify middleware stack lazy compares using named const references
-rw-r--r--actionpack/lib/action_dispatch/middleware/stack.rb18
1 files changed, 5 insertions, 13 deletions
diff --git a/actionpack/lib/action_dispatch/middleware/stack.rb b/actionpack/lib/action_dispatch/middleware/stack.rb
index e3180dba77..4240e7a5d5 100644
--- a/actionpack/lib/action_dispatch/middleware/stack.rb
+++ b/actionpack/lib/action_dispatch/middleware/stack.rb
@@ -5,13 +5,13 @@ module ActionDispatch
class Middleware
attr_reader :args, :block
- def initialize(klass, *args, &block)
- @klass, @args, @block = klass, args, block
+ def initialize(klass_or_name, *args, &block)
+ @ref = ActiveSupport::Dependencies::Reference.new(klass_or_name)
+ @args, @block = args, block
end
def klass
- return @klass if @klass.respond_to?(:new)
- @klass = ActiveSupport::Inflector.constantize(@klass.to_s)
+ @ref.get
end
def ==(middleware)
@@ -21,11 +21,7 @@ module ActionDispatch
when Class
klass == middleware
else
- if lazy_compare?(@klass) && lazy_compare?(middleware)
- normalize(@klass) == normalize(middleware)
- else
- klass.name == normalize(middleware.to_s)
- end
+ normalize(@ref.name) == normalize(middleware)
end
end
@@ -39,10 +35,6 @@ module ActionDispatch
private
- def lazy_compare?(object)
- object.is_a?(String) || object.is_a?(Symbol)
- end
-
def normalize(object)
object.to_s.strip.sub(/^::/, '')
end