module AbstractController::Rendering

def _normalize_args(action=nil, options={})

:api: plugin
render "foo/bar" to render :file => "foo/bar".
Normalize args by converting render "foo" to render :action => "foo" and
def _normalize_args(action=nil, options={})
  case action
  when NilClass
  when Hash
    options = action
  when String, Symbol
    action = action.to_s
    key = action.include?(?/) ? :file : :action
    options[key] = action
  else
    options[:partial] = action
  end
  options
end

def _normalize_options(options)

:api: plugin
Normalize options.
def _normalize_options(options)
  if options[:partial] == true
    options[:partial] = action_name
  end
  if (options.keys & [:partial, :file, :template]).empty?
    options[:prefixes] ||= _prefixes
  end
  options[:template] ||= (options[:action] || action_name).to_s
  options
end

def _normalize_render(*args, &block)

:api: private
Normalize args and options.
def _normalize_render(*args, &block)
  options = _normalize_args(*args, &block)
  _normalize_options(options)
  options
end

def _process_options(options)

:api: plugin
Process extra options.
def _process_options(options)
end

def _render_template(options) #:nodoc:

:nodoc:
:api: private
Find and renders a template based on the options given.
def _render_template(options) #:nodoc:
  lookup_context.rendered_format = nil if options[:formats]
  view_renderer.render(view_context, options)
end

def process(*) #:nodoc:

:nodoc:
Overwrite process to setup I18n proxy.
def process(*) #:nodoc:
  old_config, I18n.config = I18n.config, I18nProxy.new(I18n.config, lookup_context)
  super
ensure
  I18n.config = old_config
end

def render(*args, &block)

sticks the result in self.response_body.
Normalize arguments, options and then delegates render_to_body and
def render(*args, &block)
  options = _normalize_render(*args, &block)
  self.response_body = render_to_body(options)
end

def render_to_body(options = {})

:api: plugin
Raw rendering of a template to a Rack-compatible body.
def render_to_body(options = {})
  _process_options(options)
  _render_template(options)
end

def render_to_string(*args, &block)

:api: plugin
render_response into a String.
Raw rendering of a template to a string. Just convert the results of
def render_to_string(*args, &block)
  options = _normalize_render(*args, &block)
  render_to_body(options)
end

def view_assigns

:api: public
You can overwrite this configuration per controller.
This method should return a hash with assigns.
def view_assigns
  hash = {}
  variables  = instance_variable_names
  variables -= protected_instance_variables
  variables -= DEFAULT_PROTECTED_INSTANCE_VARIABLES
  variables.each { |name| hash[name.to_s[1, name.length]] = instance_variable_get(name) }
  hash
end

def view_context

Override this method in a module to change the default behavior.

Returns String with the rendered template
View#render[options]
Create a new ActionView instance for a controller
View.new[lookup_context, assigns, controller]
The view class must have the following methods:

An instance of a view class. The default view class is ActionView::Base
def view_context
  view_context_class.new(view_renderer, view_assigns, self)
end

def view_context_class

def view_context_class
  @_view_context_class ||= self.class.view_context_class
end

def view_renderer

Returns an object that is able to render templates.
def view_renderer
  @_view_renderer ||= ActionView::Renderer.new(lookup_context)
end