class ActionView::Template::Handlers::ERB

Experimental RBS support (using type sampling data from the type_fusion project).

# sig/action_view/template/handlers/erb.rbs

class ActionView::Template::Handlers::ERB
  def self.call: ((Class | ActionView::Template) template, String source) -> String
  def call: ((Class | ActionView::Template) template, String source) -> String
  def valid_encoding: (String string, nil encoding) -> Encoding
end

def self.call(template, source)

Experimental RBS support (using type sampling data from the type_fusion project).

def self.call: ((Class | ActionView::Template) template, String source) -> String

This signature was generated using 10 samples from 1 application.

def self.call(template, source)
  new.call(template, source)
end

def call(template, source)

Experimental RBS support (using type sampling data from the type_fusion project).

def call: ((Class | ActionView::Template) template, String source) -> String

This signature was generated using 10 samples from 1 application.

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.b
  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!
  # Strip trailing newlines from the template if enabled
  erb.chomp! if strip_trailing_newlines
  options = {
    escape: (self.class.escape_ignore_list.include? template.type),
    trim: (self.class.erb_trim_mode == "-")
  }
  if ActionView::Base.annotate_rendered_view_with_filenames && template.format == :html
    options[:preamble] = "@output_buffer.safe_append='<!-- BEGIN #{template.short_identifier} -->';"
    options[:postamble] = "@output_buffer.safe_append='<!-- END #{template.short_identifier} -->';@output_buffer.to_s"
  end
  self.class.erb_implementation.new(erb, options).src
end

def handles_encoding?

def handles_encoding?
  true
end

def supports_streaming?

def supports_streaming?
  true
end

def valid_encoding(string, encoding)

Experimental RBS support (using type sampling data from the type_fusion project).

def valid_encoding: (String string, nil encoding) -> Encoding

This signature was generated using 9 samples from 1 application.

def valid_encoding(string, encoding)
  # If a magic encoding comment was found, tag the
  # String with this encoding. This is for a case
  # where the original String was assumed to be,
  # for instance, UTF-8, but a magic comment
  # proved otherwise
  string.force_encoding(encoding) if encoding
  # If the String is valid, return the encoding we found
  return string.encoding if string.valid_encoding?
  # Otherwise, raise an exception
  raise WrongEncodingError.new(string, string.encoding)
end