Module: ActionView::TemplateHandlers

Included in:
Template
Defined in:
lib/action_view/template_handler.rb,
lib/action_view/template_handlers.rb,
lib/action_view/template_handlers/erb.rb,
lib/action_view/template_handlers/rjs.rb,
lib/action_view/template_handlers/builder.rb

Overview

:nodoc:

Defined Under Namespace

Modules: Compilable Classes: Builder, ERB, RJS

Constant Summary collapse

@@template_handlers =
{}
@@default_template_handlers =
nil

Class Method Summary collapse

Instance Method Summary collapse

Class Method Details

.extended(base) ⇒ Object



8
9
10
11
12
13
14
15
16
# File 'lib/action_view/template_handlers.rb', line 8

def self.extended(base)
  base.register_default_template_handler :erb, TemplateHandlers::ERB
  base.register_template_handler :rjs, TemplateHandlers::RJS
  base.register_template_handler :builder, TemplateHandlers::Builder

  # TODO: Depreciate old template extensions
  base.register_template_handler :rhtml, TemplateHandlers::ERB
  base.register_template_handler :rxml, TemplateHandlers::Builder
end

Instance Method Details

#handler_class_for_extension(extension) ⇒ Object



41
42
43
# File 'lib/action_view/template_handlers.rb', line 41

def handler_class_for_extension(extension)
  (extension && @@template_handlers[extension.to_sym]) || @@default_template_handlers
end

#register_default_template_handler(extension, klass) ⇒ Object



36
37
38
39
# File 'lib/action_view/template_handlers.rb', line 36

def register_default_template_handler(extension, klass)
  register_template_handler(extension, klass)
  @@default_template_handlers = klass
end

#register_template_handler(extension, klass) ⇒ Object

Register a class that knows how to handle template files with the given extension. This can be used to implement new template types. The constructor for the class must take the ActiveView::Base instance as a parameter, and the class must implement a render method that takes the contents of the template to render as well as the Hash of local assigns available to the template. The render method ought to return the rendered template as a string.



28
29
30
# File 'lib/action_view/template_handlers.rb', line 28

def register_template_handler(extension, klass)
  @@template_handlers[extension.to_sym] = klass
end

#template_handler_extensionsObject



32
33
34
# File 'lib/action_view/template_handlers.rb', line 32

def template_handler_extensions
  @@template_handlers.keys.map(&:to_s).sort
end