- def call_filter(chain, index)
- return (performed? || perform_action_without_filters) if index >= chain.size
- filter = chain[index]
- return call_filter(chain, index.next) if self.class.filter_excluded_from_action?(filter,action_name)
- halted = false
- filter.call(self) do
- halted = call_filter(chain, index.next)
- end
- halt_filter_chain(filter.filter, :no_yield) if halted == false unless @before_filter_chain_aborted
- halted
- end
在control 的 around_filter的函数和代码块中,总是会需要yield, 那么这个yield
执行的参数是什么呢,就是上面的 call_filter(chain,index.next). 通过这几行代码,就可以解释如下代码的调用结果
"---------test_one-------------"
"-----------test_two-----------"
"--------end of test_two-------"
"---------end of test_one------"
- around_filter :test_one
- around_filter :test_two
- def test_one
- p "---------test_one-------------"
- yield
- p "---------end of test_one------"
- end
- def test_two
- p "-----------test_two-----------"
- yield
- p "--------end of test_two-------"
- end