Module: ActionView::Template::Handlers
- Included in:
- ActionView::Template
- Defined in:
- lib/action_view/template/handlers.rb,
lib/action_view/template/handlers/erb.rb,
lib/action_view/template/handlers/raw.rb,
lib/action_view/template/handlers/html.rb,
lib/action_view/template/handlers/builder.rb,
lib/action_view/template/handlers/erb/erubi.rb
Overview
Defined Under Namespace
Classes: Builder, ERB, Html, LegacyHandlerWrapper, Raw
Constant Summary
collapse
- @@template_handlers =
{}
- @@default_template_handlers =
nil
Class Method Summary
collapse
Instance Method Summary
collapse
Class Method Details
.extended(base) ⇒ Object
14
15
16
17
18
19
20
|
# File 'lib/action_view/template/handlers.rb', line 14
def self.extended(base)
base.register_default_template_handler :raw, Raw.new
base.register_template_handler :erb, ERB.new
base.register_template_handler :html, Html.new
base.register_template_handler :builder, Builder.new
base.register_template_handler :ruby, lambda { |_, source| source }
end
|
.extensions ⇒ Object
25
26
27
|
# File 'lib/action_view/template/handlers.rb', line 25
def self.extensions
@@template_extensions ||= @@template_handlers.keys
end
|
Instance Method Details
#handler_for_extension(extension) ⇒ Object
87
88
89
|
# File 'lib/action_view/template/handlers.rb', line 87
def handler_for_extension(extension)
registered_template_handler(extension) || @@default_template_handlers
end
|
#register_default_template_handler(extension, klass) ⇒ Object
82
83
84
85
|
# File 'lib/action_view/template/handlers.rb', line 82
def register_default_template_handler(extension, klass)
register_template_handler(extension, klass)
@@default_template_handlers = klass
end
|
#register_template_handler(*extensions, handler) ⇒ Object
Register an object that knows how to handle template files with the given extensions. This can be used to implement new template types. The handler must respond to :call
, which will be passed the template and should return the rendered template as a String.
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
|
# File 'lib/action_view/template/handlers.rb', line 39
def register_template_handler(*extensions, handler)
params = if handler.is_a?(Proc)
handler.parameters
else
handler.method(:call).parameters
end
unless params.find_all { |type, _| type == :req || type == :opt }.length >= 2
ActiveSupport::Deprecation.warn <<~eowarn
Single arity template handlers are deprecated. Template handlers must
now accept two parameters, the view object and the source for the view object.
Change:
>> #{handler}.call(#{params.map(&:last).join(", ")})
To:
>> #{handler}.call(#{params.map(&:last).join(", ")}, source)
eowarn
handler = LegacyHandlerWrapper.new(handler)
end
raise(ArgumentError, "Extension is required") if extensions.empty?
extensions.each do |extension|
@@template_handlers[extension.to_sym] = handler
end
@@template_extensions = nil
end
|
#registered_template_handler(extension) ⇒ Object
78
79
80
|
# File 'lib/action_view/template/handlers.rb', line 78
def registered_template_handler(extension)
extension && @@template_handlers[extension.to_sym]
end
|
#template_handler_extensions ⇒ Object
74
75
76
|
# File 'lib/action_view/template/handlers.rb', line 74
def template_handler_extensions
@@template_handlers.keys.map(&:to_s).sort
end
|
#unregister_template_handler(*extensions) ⇒ Object
Opposite to register_template_handler.
66
67
68
69
70
71
72
|
# File 'lib/action_view/template/handlers.rb', line 66
def unregister_template_handler(*extensions)
extensions.each do |extension|
handler = @@template_handlers.delete extension.to_sym
@@default_template_handlers = nil if @@default_template_handlers == handler
end
@@template_extensions = nil
end
|