mirror of
https://github.com/rails/rails.git
synced 2022-11-09 12:12:34 -05:00
Do not hard code encoding to UTF8
This commit is contained in:
parent
fde9af0678
commit
19292a70fb
2 changed files with 54 additions and 48 deletions
|
@ -173,49 +173,18 @@ module ActionView
|
||||||
@inspect ||= defined?(Rails.root) ? identifier.sub("#{Rails.root}/", '') : identifier
|
@inspect ||= defined?(Rails.root) ? identifier.sub("#{Rails.root}/", '') : identifier
|
||||||
end
|
end
|
||||||
|
|
||||||
protected
|
# This method is responsible for properly setting he encoding of the
|
||||||
|
# source. Until this point, we assume that the source is BINARY data.
|
||||||
# Compile a template. This method ensures a template is compiled
|
# If no additional information is supplied, we assume the encoding is
|
||||||
# just once and removes the source after it is compiled.
|
# the same as <tt>Encoding.default_external</tt>.
|
||||||
def compile!(view) #:nodoc:
|
|
||||||
return if @compiled
|
|
||||||
|
|
||||||
if view.is_a?(ActionView::CompiledTemplates)
|
|
||||||
mod = ActionView::CompiledTemplates
|
|
||||||
else
|
|
||||||
mod = view.singleton_class
|
|
||||||
end
|
|
||||||
|
|
||||||
compile(view, mod)
|
|
||||||
|
|
||||||
# Just discard the source if we have a virtual path. This
|
|
||||||
# means we can get the template back.
|
|
||||||
@source = nil if @virtual_path
|
|
||||||
@compiled = true
|
|
||||||
end
|
|
||||||
|
|
||||||
# Among other things, this method is responsible for properly setting
|
|
||||||
# the encoding of the source. Until this point, we assume that the
|
|
||||||
# source is BINARY data. If no additional information is supplied,
|
|
||||||
# we assume the encoding is the same as <tt>Encoding.default_external</tt>.
|
|
||||||
#
|
#
|
||||||
# The user can also specify the encoding via a comment on the first
|
# The user can also specify the encoding via a comment on the first
|
||||||
# line of the template (# encoding: NAME-OF-ENCODING). This will work
|
# line of the template (# encoding: NAME-OF-ENCODING). This will work
|
||||||
# with any template engine, as we process out the encoding comment
|
# with any template engine, as we process out the encoding comment
|
||||||
# before passing the source on to the template engine, leaving a
|
# before passing the source on to the template engine, leaving a
|
||||||
# blank line in its stead.
|
# blank line in its stead.
|
||||||
#
|
def encode!
|
||||||
# If the template engine handles encodings, we send the encoded
|
return unless source.encoding == Encoding::BINARY
|
||||||
# String to the engine without further processing. This allows
|
|
||||||
# the template engine to support additional mechanisms for
|
|
||||||
# specifying the encoding. For instance, ERB supports <%# encoding: %>
|
|
||||||
#
|
|
||||||
# Otherwise, after we figure out the correct encoding, we then
|
|
||||||
# encode the source into <tt>Encoding.default_internal</tt>.
|
|
||||||
# In general, this means that templates will be UTF-8 inside of Rails,
|
|
||||||
# regardless of the original source encoding.
|
|
||||||
def compile(view, mod) #:nodoc:
|
|
||||||
method_name = self.method_name
|
|
||||||
|
|
||||||
if source.encoding_aware?
|
if source.encoding_aware?
|
||||||
# Look for # encoding: *. If we find one, we'll encode the
|
# Look for # encoding: *. If we find one, we'll encode the
|
||||||
|
@ -248,7 +217,44 @@ module ActionView
|
||||||
raise WrongEncodingError.new(source, encoding)
|
raise WrongEncodingError.new(source, encoding)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
protected
|
||||||
|
|
||||||
|
# Compile a template. This method ensures a template is compiled
|
||||||
|
# just once and removes the source after it is compiled.
|
||||||
|
def compile!(view) #:nodoc:
|
||||||
|
return if @compiled
|
||||||
|
|
||||||
|
if view.is_a?(ActionView::CompiledTemplates)
|
||||||
|
mod = ActionView::CompiledTemplates
|
||||||
|
else
|
||||||
|
mod = view.singleton_class
|
||||||
|
end
|
||||||
|
|
||||||
|
compile(view, mod)
|
||||||
|
|
||||||
|
# Just discard the source if we have a virtual path. This
|
||||||
|
# means we can get the template back.
|
||||||
|
@source = nil if @virtual_path
|
||||||
|
@compiled = true
|
||||||
|
end
|
||||||
|
|
||||||
|
# Among other things, this method is responsible for properly setting
|
||||||
|
# the encoding of the compiled template.
|
||||||
|
#
|
||||||
|
# If the template engine handles encodings, we send the encoded
|
||||||
|
# String to the engine without further processing. This allows
|
||||||
|
# the template engine to support additional mechanisms for
|
||||||
|
# specifying the encoding. For instance, ERB supports <%# encoding: %>
|
||||||
|
#
|
||||||
|
# Otherwise, after we figure out the correct encoding, we then
|
||||||
|
# encode the source into <tt>Encoding.default_internal</tt>.
|
||||||
|
# In general, this means that templates will be UTF-8 inside of Rails,
|
||||||
|
# regardless of the original source encoding.
|
||||||
|
def compile(view, mod) #:nodoc:
|
||||||
|
encode!
|
||||||
|
method_name = self.method_name
|
||||||
code = @handler.call(self)
|
code = @handler.call(self)
|
||||||
|
|
||||||
# Make sure that the resulting String to be evalled is in the
|
# Make sure that the resulting String to be evalled is in the
|
||||||
|
@ -297,7 +303,11 @@ module ActionView
|
||||||
raise e
|
raise e
|
||||||
else
|
else
|
||||||
assigns = view.respond_to?(:assigns) ? view.assigns : {}
|
assigns = view.respond_to?(:assigns) ? view.assigns : {}
|
||||||
template = @virtual_path ? refresh(view) : self
|
template = self
|
||||||
|
unless template.source
|
||||||
|
template = refresh(view)
|
||||||
|
template.encode!
|
||||||
|
end
|
||||||
raise Template::Error.new(template, assigns, e)
|
raise Template::Error.new(template, assigns, e)
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
|
|
@ -89,14 +89,10 @@ module ActionView
|
||||||
line_counter = start_on_line
|
line_counter = start_on_line
|
||||||
return unless source_code = source_code[start_on_line..end_on_line]
|
return unless source_code = source_code[start_on_line..end_on_line]
|
||||||
|
|
||||||
extract = source_code.sum do |line|
|
source_code.sum do |line|
|
||||||
line_counter += 1
|
line_counter += 1
|
||||||
"#{indent}#{line_counter}: #{line}\n"
|
"#{indent}#{line_counter}: #{line}\n"
|
||||||
end
|
end
|
||||||
|
|
||||||
extract.force_encoding("UTF-8") if extract.respond_to?(:encode!)
|
|
||||||
|
|
||||||
extract
|
|
||||||
end
|
end
|
||||||
|
|
||||||
def sub_template_of(template_path)
|
def sub_template_of(template_path)
|
||||||
|
|
Loading…
Reference in a new issue