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
93 94 95 |
# File 'lib/action_view/template/handlers/erb.rb', line 93 def self.call(template) new.call(template) end |
Instance Method Details
#call(template) ⇒ Object
105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 |
# File 'lib/action_view/template/handlers/erb.rb', line 105 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 |
#handles_encoding? ⇒ Boolean
101 102 103 |
# File 'lib/action_view/template/handlers/erb.rb', line 101 def handles_encoding? true end |
#supports_streaming? ⇒ Boolean
97 98 99 |
# File 'lib/action_view/template/handlers/erb.rb', line 97 def supports_streaming? true end |