aboutsummaryrefslogtreecommitdiffstats
path: root/actionpack
diff options
context:
space:
mode:
Diffstat (limited to 'actionpack')
-rw-r--r--actionpack/CHANGELOG2
-rw-r--r--actionpack/lib/action_controller/filters.rb8
2 files changed, 5 insertions, 5 deletions
diff --git a/actionpack/CHANGELOG b/actionpack/CHANGELOG
index c57e1ec917..08e945fdb8 100644
--- a/actionpack/CHANGELOG
+++ b/actionpack/CHANGELOG
@@ -1,5 +1,7 @@
*SVN*
+* Correctly report which filter halted the chain. #6699 [Martin Emde]
+
* Fix a bug in Routing where a parameter taken from the path of the current request could not be used as a query parameter for the next. Closes #6752. [Nicholas Seckar]
* Unrescued ActiveRecord::RecordNotFound responds with 404 instead of 500. [Jeremy Kemper]
diff --git a/actionpack/lib/action_controller/filters.rb b/actionpack/lib/action_controller/filters.rb
index 113dba05d2..9f3d1e58d9 100644
--- a/actionpack/lib/action_controller/filters.rb
+++ b/actionpack/lib/action_controller/filters.rb
@@ -616,10 +616,7 @@ module ActionController #:nodoc:
end
def perform_action_with_filters
- #result = perform_filters do
- # perform_action_without_filters unless performed?
- #end
- @before_filter_chain_aborted = (call_filter(self.class.filter_chain, 0) == false)
+ call_filter(self.class.filter_chain, 0)
end
def process_with_filters(request, response, method = :perform_action, *arguments) #:nodoc:
@@ -640,7 +637,7 @@ module ActionController #:nodoc:
filter.call(self) do
halted = call_filter(chain, index.next)
end
- halt_filter_chain(filter.filter, :no_yield) if halted == false
+ halt_filter_chain(filter.filter, :no_yield) if halted == false unless @before_filter_chain_aborted
halted
end
@@ -653,6 +650,7 @@ module ActionController #:nodoc:
logger.info "Filter chain halted as [#{filter.inspect}] returned false."
end
end
+ @before_filter_chain_aborted = true
return false
end