Class: ActionView::Template::Handlers::ERB
Relationships & Source Files | |
Namespace Children | |
Classes:
| |
Inherits: | Object |
Defined in: | actionview/lib/action_view/template/handlers/erb.rb, actionview/lib/action_view/template/handlers/erb/erubi.rb |
Constant Summary
-
ENCODING_TAG =
# File 'actionview/lib/action_view/template/handlers/erb.rb', line 19Regexp.new("\\A(<%#{ENCODING_FLAG}-?%>)[ \\t]*")
Class Attribute Summary
Class Method Summary
Instance Attribute Summary
Instance Method Summary
Class Attribute Details
.erb_implementation (rw)
[ GitHub ]# File 'actionview/lib/action_view/template/handlers/erb.rb', line 14
class_attribute :erb_implementation, default: Erubi
.erb_implementation? ⇒ Boolean
(rw)
[ GitHub ]
# File 'actionview/lib/action_view/template/handlers/erb.rb', line 14
class_attribute :erb_implementation, default: Erubi
.erb_trim_mode (rw)
[ GitHub ]# File 'actionview/lib/action_view/template/handlers/erb.rb', line 11
class_attribute :erb_trim_mode, default: "-"
.erb_trim_mode? ⇒ Boolean
(rw)
[ GitHub ]
# File 'actionview/lib/action_view/template/handlers/erb.rb', line 11
class_attribute :erb_trim_mode, default: "-"
.escape_whitelist (rw)
[ GitHub ]# File 'actionview/lib/action_view/template/handlers/erb.rb', line 17
class_attribute :escape_whitelist, default: ["text/plain"]
.escape_whitelist? ⇒ Boolean
(rw)
[ GitHub ]
# File 'actionview/lib/action_view/template/handlers/erb.rb', line 17
class_attribute :escape_whitelist, default: ["text/plain"]
Class Method Details
.call(template)
[ GitHub ]# File 'actionview/lib/action_view/template/handlers/erb.rb', line 21
def self.call(template) new.call(template) end
Instance Attribute Details
#erb_implementation (rw)
[ GitHub ]# File 'actionview/lib/action_view/template/handlers/erb.rb', line 14
class_attribute :erb_implementation, default: Erubi
#erb_implementation? ⇒ Boolean
(rw)
[ GitHub ]
# File 'actionview/lib/action_view/template/handlers/erb.rb', line 14
class_attribute :erb_implementation, default: Erubi
#erb_trim_mode (rw)
[ GitHub ]# File 'actionview/lib/action_view/template/handlers/erb.rb', line 11
class_attribute :erb_trim_mode, default: "-"
#erb_trim_mode? ⇒ Boolean
(rw)
[ GitHub ]
# File 'actionview/lib/action_view/template/handlers/erb.rb', line 11
class_attribute :erb_trim_mode, default: "-"
#escape_whitelist (rw)
[ GitHub ]# File 'actionview/lib/action_view/template/handlers/erb.rb', line 17
class_attribute :escape_whitelist, default: ["text/plain"]
#escape_whitelist? ⇒ Boolean
(rw)
[ GitHub ]
# File 'actionview/lib/action_view/template/handlers/erb.rb', line 17
class_attribute :escape_whitelist, default: ["text/plain"]
#handles_encoding? ⇒ Boolean
(readonly)
[ GitHub ]
# File 'actionview/lib/action_view/template/handlers/erb.rb', line 29
def handles_encoding? true end
#supports_streaming? ⇒ Boolean
(readonly)
[ GitHub ]
# File 'actionview/lib/action_view/template/handlers/erb.rb', line 25
def supports_streaming? true end
Instance Method Details
#call(template)
[ GitHub ]# File 'actionview/lib/action_view/template/handlers/erb.rb', line 33
def call(template) # First, convert to BINARY, so in case the encoding is # wrong, we can still find an encoding tag # (<%# encoding %>) inside the String using a regular # expression template_source = template.source.dup.force_encoding(Encoding::ASCII_8BIT) erb = template_source.gsub(ENCODING_TAG, "") encoding = $2 erb.force_encoding valid_encoding(template.source.dup, encoding) # Always make sure we return a String in the default_internal erb.encode! self.class.erb_implementation.new( erb, escape: (self.class.escape_whitelist.include? template.type), trim: (self.class.erb_trim_mode == "-") ).src end