Bugfixes and Rails Edge
Update to Rails 2.3.1. (Actually, not quite. Doesn't look like 2.3.1 will be released today, but I REALLY want to push these bugfixes out.) Removed bundled Rack (Rails 2.3.1 comes bundled with Rack 1.0). Add config.action_view.cache_template_loading = true to production environment. Fix FastCGI bug (http://rubyforge.org/tracker/index.php?func=detail&aid=24191&group_id=186&atid=783). Fix WikiWords bug (http://rubyforge.org/pipermail/instiki-users/2009-February/001181.html).
This commit is contained in:
parent
0ddef97328
commit
133c21b801
641 changed files with 20541 additions and 71675 deletions
|
@ -22,7 +22,7 @@ module ActionController #:nodoc:
|
|||
attr_reader :allowed_methods
|
||||
|
||||
def initialize(*allowed_methods)
|
||||
super("Only #{allowed_methods.to_sentence} requests are allowed.")
|
||||
super("Only #{allowed_methods.to_sentence(:locale => :en)} requests are allowed.")
|
||||
@allowed_methods = allowed_methods
|
||||
end
|
||||
|
||||
|
@ -784,9 +784,37 @@ module ActionController #:nodoc:
|
|||
# # placed in "app/views/layouts/special.r(html|xml)"
|
||||
# render :text => "Hi there!", :layout => "special"
|
||||
#
|
||||
# The <tt>:text</tt> option can also accept a Proc object, which can be used to manually control the page generation. This should
|
||||
# generally be avoided, as it violates the separation between code and content, and because almost everything that can be
|
||||
# done with this method can also be done more cleanly using one of the other rendering methods, most notably templates.
|
||||
# === Streaming data and/or controlling the page generation
|
||||
#
|
||||
# The <tt>:text</tt> option can also accept a Proc object, which can be used to:
|
||||
#
|
||||
# 1. stream on-the-fly generated data to the browser. Note that you should
|
||||
# use the methods provided by ActionController::Steaming instead if you
|
||||
# want to stream a buffer or a file.
|
||||
# 2. manually control the page generation. This should generally be avoided,
|
||||
# as it violates the separation between code and content, and because almost
|
||||
# everything that can be done with this method can also be done more cleanly
|
||||
# using one of the other rendering methods, most notably templates.
|
||||
#
|
||||
# Two arguments are passed to the proc, a <tt>response</tt> object and an
|
||||
# <tt>output</tt> object. The response object is equivalent to the return
|
||||
# value of the ActionController::Base#response method, and can be used to
|
||||
# control various things in the HTTP response, such as setting the
|
||||
# Content-Type header. The output object is an writable <tt>IO</tt>-like
|
||||
# object, so one can call <tt>write</tt> and <tt>flush</tt> on it.
|
||||
#
|
||||
# The following example demonstrates how one can stream a large amount of
|
||||
# on-the-fly generated data to the browser:
|
||||
#
|
||||
# # Streams about 180 MB of generated data to the browser.
|
||||
# render :text => proc { |response, output|
|
||||
# 10_000_000.times do |i|
|
||||
# output.write("This is line #{i}\n")
|
||||
# output.flush
|
||||
# end
|
||||
# }
|
||||
#
|
||||
# Another example:
|
||||
#
|
||||
# # Renders "Hello from code!"
|
||||
# render :text => proc { |response, output| output.write("Hello from code!") }
|
||||
|
@ -885,6 +913,7 @@ module ActionController #:nodoc:
|
|||
layout = pick_layout(options)
|
||||
response.layout = layout.path_without_format_and_extension if layout
|
||||
logger.info("Rendering template within #{layout.path_without_format_and_extension}") if logger && layout
|
||||
layout = layout.path_without_format_and_extension if layout
|
||||
|
||||
if content_type = options[:content_type]
|
||||
response.content_type = content_type.to_s
|
||||
|
@ -1269,7 +1298,7 @@ module ActionController #:nodoc:
|
|||
rescue ActionView::MissingTemplate => e
|
||||
# Was the implicit template missing, or was it another template?
|
||||
if e.path == default_template_name
|
||||
raise UnknownAction, "No action responded to #{action_name}. Actions: #{action_methods.sort.to_sentence}", caller
|
||||
raise UnknownAction, "No action responded to #{action_name}. Actions: #{action_methods.sort.to_sentence(:locale => :en)}", caller
|
||||
else
|
||||
raise e
|
||||
end
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue