Class: ActionView::Template::Handlers::ERB
- Inherits:
-
ActionView::Template::Handler
- Object
- ActionView::Template::Handler
- ActionView::Template::Handlers::ERB
- Includes:
- Compilable
- 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
- #compile(template) ⇒ Object
-
#erb_trim_mode ⇒ Object
:singleton-method: Specify trim mode for the ERB compiler.
Methods included from Compilable
Methods inherited from ActionView::Template::Handler
Class Method Details
.handles_encoding? ⇒ Boolean
82 83 84 |
# File 'lib/action_view/template/handlers/erb.rb', line 82 def self.handles_encoding? true end |
Instance Method Details
#compile(template) ⇒ Object
86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 |
# File 'lib/action_view/template/handlers/erb.rb', line 86 def compile(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, :trim => (self.class.erb_trim_mode == "-") ).src end |
#erb_trim_mode ⇒ Object
:singleton-method: Specify trim mode for the ERB compiler. Defaults to ‘-’. See ERb documentation for suitable values.
72 |
# File 'lib/action_view/template/handlers/erb.rb', line 72 cattr_accessor :erb_trim_mode |