module ActionView #:nodoc: # = Action View Template Handlers class Template module Handlers #:nodoc: autoload :ERB, 'action_view/template/handlers/erb' autoload :Builder, 'action_view/template/handlers/builder' def self.extended(base) base.register_default_template_handler :erb, ERB.new base.register_template_handler :builder, Builder.new end @@template_handlers = {} @@default_template_handlers = nil def self.extensions @@template_extensions ||= @@template_handlers.keys end # 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. def register_template_handler(extension, klass) @@template_handlers[extension.to_sym] = klass end def template_handler_extensions @@template_handlers.keys.map {|key| key.to_s }.sort end def registered_template_handler(extension) extension && @@template_handlers[extension.to_sym] end def register_default_template_handler(extension, klass) register_template_handler(extension, klass) @@default_template_handlers = klass end def handler_class_for_extension(extension) ActiveSupport::Deprecation.warn "handler_class_for_extension is deprecated. " << "Please use handler_for_extension instead", caller handler_for_extension(extension) end def handler_for_extension(extension) registered_template_handler(extension) || @@default_template_handlers end end end end