mirror of
https://github.com/rails/rails.git
synced 2022-11-09 12:12:34 -05:00
Merge pull request #5454 from luke-gru/luke-dev
allow zero-arity proc for AbstrController::layout
This commit is contained in:
commit
e2b6751312
2 changed files with 44 additions and 4 deletions
|
@ -89,7 +89,7 @@ module AbstractController
|
||||||
# class TillController < BankController
|
# class TillController < BankController
|
||||||
# layout false
|
# layout false
|
||||||
#
|
#
|
||||||
# In these examples, we have three implicit lookup scenrios:
|
# In these examples, we have three implicit lookup scenarios:
|
||||||
# * The BankController uses the "bank" layout.
|
# * The BankController uses the "bank" layout.
|
||||||
# * The ExchangeController uses the "exchange" layout.
|
# * The ExchangeController uses the "exchange" layout.
|
||||||
# * The CurrencyController inherits the layout from BankController.
|
# * The CurrencyController inherits the layout from BankController.
|
||||||
|
@ -128,7 +128,14 @@ module AbstractController
|
||||||
# If you want to use an inline method, such as a proc, do something like this:
|
# If you want to use an inline method, such as a proc, do something like this:
|
||||||
#
|
#
|
||||||
# class WeblogController < ActionController::Base
|
# class WeblogController < ActionController::Base
|
||||||
# layout proc{ |controller| controller.logged_in? ? "writer_layout" : "reader_layout" }
|
# layout proc { |controller| controller.logged_in? ? "writer_layout" : "reader_layout" }
|
||||||
|
# end
|
||||||
|
#
|
||||||
|
# If an argument isn't given to the proc, it's evaluated in the context of
|
||||||
|
# the current controller anyway.
|
||||||
|
#
|
||||||
|
# class WeblogController < ActionController::Base
|
||||||
|
# layout proc { logged_in? ? "writer_layout" : "reader_layout" }
|
||||||
# end
|
# end
|
||||||
#
|
#
|
||||||
# Of course, the most common way of specifying a layout is still just as a plain template name:
|
# Of course, the most common way of specifying a layout is still just as a plain template name:
|
||||||
|
@ -300,7 +307,7 @@ module AbstractController
|
||||||
RUBY
|
RUBY
|
||||||
when Proc
|
when Proc
|
||||||
define_method :_layout_from_proc, &_layout
|
define_method :_layout_from_proc, &_layout
|
||||||
"_layout_from_proc(self)"
|
_layout.arity == 0 ? "_layout_from_proc" : "_layout_from_proc(self)"
|
||||||
when false
|
when false
|
||||||
nil
|
nil
|
||||||
when true
|
when true
|
||||||
|
|
|
@ -72,6 +72,27 @@ module AbstractControllerTests
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
||||||
|
class WithZeroArityProc < Base
|
||||||
|
layout proc { "overwrite" }
|
||||||
|
|
||||||
|
def index
|
||||||
|
render :template => ActionView::Template::Text.new("Hello zero arity proc!")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
class WithProcInContextOfInstance < Base
|
||||||
|
def an_instance_method; end
|
||||||
|
|
||||||
|
layout proc {
|
||||||
|
break unless respond_to? :an_instance_method
|
||||||
|
"overwrite"
|
||||||
|
}
|
||||||
|
|
||||||
|
def index
|
||||||
|
render :template => ActionView::Template::Text.new("Hello again zero arity proc!")
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
class WithSymbol < Base
|
class WithSymbol < Base
|
||||||
layout :hello
|
layout :hello
|
||||||
|
|
||||||
|
@ -221,6 +242,18 @@ module AbstractControllerTests
|
||||||
assert_equal "Overwrite Hello proc!", controller.response_body
|
assert_equal "Overwrite Hello proc!", controller.response_body
|
||||||
end
|
end
|
||||||
|
|
||||||
|
test "when layout is specified as a proc without parameters it works just the same" do
|
||||||
|
controller = WithZeroArityProc.new
|
||||||
|
controller.process(:index)
|
||||||
|
assert_equal "Overwrite Hello zero arity proc!", controller.response_body
|
||||||
|
end
|
||||||
|
|
||||||
|
test "when layout is specified as a proc without parameters the block is evaluated in the context of an instance" do
|
||||||
|
controller = WithProcInContextOfInstance.new
|
||||||
|
controller.process(:index)
|
||||||
|
assert_equal "Overwrite Hello again zero arity proc!", controller.response_body
|
||||||
|
end
|
||||||
|
|
||||||
test "when layout is specified as a symbol, call the requested method and use the layout returned" do
|
test "when layout is specified as a symbol, call the requested method and use the layout returned" do
|
||||||
controller = WithSymbol.new
|
controller = WithSymbol.new
|
||||||
controller.process(:index)
|
controller.process(:index)
|
||||||
|
|
Loading…
Reference in a new issue