Class: ActionView::Template::Handlers::ERB
- Inherits:
-
Object
- Object
- ActionView::Template::Handlers::ERB
- Defined in:
- lib/action_view/template/handlers/erb.rb
Constant Summary collapse
- ENCODING_TAG =
Regexp.new("\\A(<%#{ENCODING_FLAG}-?%>)[ \\t]*")
Class Method Summary collapse
Instance Method Summary collapse
Class Method Details
.call(template) ⇒ Object
68 69 70 |
# File 'lib/action_view/template/handlers/erb.rb', line 68 def self.call(template) new.call(template) end |
Instance Method Details
#call(template) ⇒ Object
80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 |
# File 'lib/action_view/template/handlers/erb.rb', line 80 def call(template) if template.source.encoding_aware? # 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("BINARY") 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! else erb = template.source.dup end self.class.erb_implementation.new( erb, :escape => (self.class.escape_whitelist.include? template.mime_type), :trim => (self.class.erb_trim_mode == "-") ).src end |
#handles_encoding? ⇒ Boolean
76 77 78 |
# File 'lib/action_view/template/handlers/erb.rb', line 76 def handles_encoding? true end |
#supports_streaming? ⇒ Boolean
72 73 74 |
# File 'lib/action_view/template/handlers/erb.rb', line 72 def supports_streaming? true end |