Class: ActionView::Template::Handlers::ERB
- Inherits:
-
Object
- Object
- ActionView::Template::Handlers::ERB
- Defined in:
- lib/action_view/template/handlers/erb.rb,
lib/action_view/template/handlers/erb/erubi.rb
Defined Under Namespace
Classes: Erubi
Constant Summary collapse
- ENCODING_TAG =
Regexp.new("\\A(<%#{ENCODING_FLAG}-?%>)[ \\t]*")
Class Method Summary collapse
Instance Method Summary collapse
Class Method Details
.call(template, source) ⇒ Object
31 32 33 |
# File 'lib/action_view/template/handlers/erb.rb', line 31 def self.call(template, source) new.call(template, source) end |
Instance Method Details
#call(template, source) ⇒ Object
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/erb.rb', line 43 def call(template, source) # 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 = source.dup.force_encoding(Encoding::ASCII_8BIT) erb = template_source.gsub(ENCODING_TAG, "") encoding = $2 erb.force_encoding valid_encoding(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_ignore_list.include? template.type), trim: (self.class.erb_trim_mode == "-") ).src end |
#handles_encoding? ⇒ Boolean
39 40 41 |
# File 'lib/action_view/template/handlers/erb.rb', line 39 def handles_encoding? true end |
#supports_streaming? ⇒ Boolean
35 36 37 |
# File 'lib/action_view/template/handlers/erb.rb', line 35 def supports_streaming? true end |