diff options
author | Yehuda Katz <wycats@gmail.com> | 2009-03-19 15:45:48 -0700 |
---|---|---|
committer | Yehuda Katz <wycats@gmail.com> | 2009-03-19 15:45:48 -0700 |
commit | 890321e51e0c51f61f9198d247727e98f7485899 (patch) | |
tree | 19457c8d5e9bff3d3b3b16fc4861964e5297957c /actionpack/lib/action_controller/abstract | |
parent | 8ab37c76608d7105c47566e79b85fcf72cb11e4b (diff) | |
download | rails-890321e51e0c51f61f9198d247727e98f7485899.tar.gz rails-890321e51e0c51f61f9198d247727e98f7485899.tar.bz2 rails-890321e51e0c51f61f9198d247727e98f7485899.zip |
Get very basic layouts working.
* Required small architecture change
Diffstat (limited to 'actionpack/lib/action_controller/abstract')
-rw-r--r-- | actionpack/lib/action_controller/abstract/layouts.rb | 7 | ||||
-rw-r--r-- | actionpack/lib/action_controller/abstract/renderer.rb | 47 |
2 files changed, 34 insertions, 20 deletions
diff --git a/actionpack/lib/action_controller/abstract/layouts.rb b/actionpack/lib/action_controller/abstract/layouts.rb index c8d6e77fce..c6b99a6d45 100644 --- a/actionpack/lib/action_controller/abstract/layouts.rb +++ b/actionpack/lib/action_controller/abstract/layouts.rb @@ -1,10 +1,7 @@ module AbstractController module Layouts - def _render_template(tmp) - _action_view._render_template_with_layout(tmp, _layout) - end - - def _layout + def _render_template(template, options) + _action_view._render_template_with_layout(template, options[:_layout]) end end end
\ No newline at end of file diff --git a/actionpack/lib/action_controller/abstract/renderer.rb b/actionpack/lib/action_controller/abstract/renderer.rb index 19a64b0c38..ad996d0daf 100644 --- a/actionpack/lib/action_controller/abstract/renderer.rb +++ b/actionpack/lib/action_controller/abstract/renderer.rb @@ -4,12 +4,14 @@ module AbstractController module Renderer def self.included(klass) - klass.class_eval do + klass.class_eval do extend ClassMethods + attr_internal :formats - - extlib_inheritable_accessor :view_paths - self.view_paths ||= ActionView::PathSet.new + + extlib_inheritable_accessor :_view_paths + + self._view_paths ||= ActionView::PathSet.new include AbstractController::Logger end end @@ -17,27 +19,42 @@ module AbstractController def _action_view @_action_view ||= ActionView::Base.new(self.class.view_paths, {}, self) end - - def _prefix - end - - def render(template = action_name) - self.response_body = render_to_string(template) + + def render(name = action_name, options = {}) + self.response_body = render_to_string(name, options) end - def render_to_string(template = action_name, prefix = true) - tmp = view_paths.find_by_parts(template.to_s, formats, (_prefix if prefix)) - _render_template(tmp) + # Raw rendering of a template. + # ==== + # @option _prefix<String> The template's path prefix + # @option _layout<String> The relative path to the layout template to use + # + # :api: plugin + def render_to_string(name = action_name, options = {}) + template = view_paths.find_by_parts(name.to_s, formats, options[:_prefix]) + _render_template(template, options) end - def _render_template(tmp) - _action_view._render_template_with_layout(tmp) + def _render_template(template, options) + _action_view._render_template_with_layout(template) end + + def view_paths() _view_paths end module ClassMethods + def append_view_path(path) self.view_paths << path end + + def view_paths + self._view_paths + end + + def view_paths=(paths) + self._view_paths = paths.is_a?(ActionView::PathSet) ? + paths : ActionView::Base.process_view_paths(paths) + end end end end
\ No newline at end of file |