mirror of
https://github.com/rails/rails.git
synced 2022-11-09 12:12:34 -05:00
67 lines
1.4 KiB
Ruby
67 lines
1.4 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
require "active_support/core_ext/string/output_safety"
|
|
|
|
module ActionView
|
|
# Used as a buffer for views
|
|
#
|
|
# The main difference between this and ActiveSupport::SafeBuffer
|
|
# is for the methods `<<` and `safe_expr_append=` the inputs are
|
|
# checked for nil before they are assigned and `to_s` is called on
|
|
# the input. For example:
|
|
#
|
|
# obuf = ActionView::OutputBuffer.new "hello"
|
|
# obuf << 5
|
|
# puts obuf # => "hello5"
|
|
#
|
|
# sbuf = ActiveSupport::SafeBuffer.new "hello"
|
|
# sbuf << 5
|
|
# puts sbuf # => "hello\u0005"
|
|
#
|
|
class OutputBuffer < ActiveSupport::SafeBuffer #:nodoc:
|
|
def initialize(*)
|
|
super
|
|
encode!
|
|
end
|
|
|
|
def <<(value)
|
|
return self if value.nil?
|
|
super(value.to_s)
|
|
end
|
|
alias :append= :<<
|
|
|
|
def safe_expr_append=(val)
|
|
return self if val.nil?
|
|
safe_concat val.to_s
|
|
end
|
|
|
|
alias :safe_append= :safe_concat
|
|
end
|
|
|
|
class StreamingBuffer #:nodoc:
|
|
def initialize(block)
|
|
@block = block
|
|
end
|
|
|
|
def <<(value)
|
|
value = value.to_s
|
|
value = ERB::Util.h(value) unless value.html_safe?
|
|
@block.call(value)
|
|
end
|
|
alias :concat :<<
|
|
alias :append= :<<
|
|
|
|
def safe_concat(value)
|
|
@block.call(value.to_s)
|
|
end
|
|
alias :safe_append= :safe_concat
|
|
|
|
def html_safe?
|
|
true
|
|
end
|
|
|
|
def html_safe
|
|
self
|
|
end
|
|
end
|
|
end
|