Methods
Constants
ENCODING_TAG | = | Regexp.new("\\A(<%#{ENCODING_FLAG}-?%>)[ \\t]*") |
Class Public methods
call(template, source)
📝 Source code
# File actionview/lib/action_view/template/handlers/erb.rb, line 31
def self.call(template, source)
new.call(template, source)
end
🔎 See on GitHub
Instance Public methods
call(template, source)
📝 Source code
# File actionview/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
🔎 See on GitHub
handles_encoding?()
📝 Source code
# File actionview/lib/action_view/template/handlers/erb.rb, line 39
def handles_encoding?
true
end
🔎 See on GitHub
supports_streaming?()
📝 Source code
# File actionview/lib/action_view/template/handlers/erb.rb, line 35
def supports_streaming?
true
end
🔎 See on GitHub