1
0
Fork 0
mirror of https://github.com/rails/rails.git synced 2022-11-09 12:12:34 -05:00
rails--rails/actionview/lib/action_view/buffers.rb

68 lines
1.4 KiB
Ruby
Raw Normal View History

# frozen_string_literal: true
require "active_support/core_ext/string/output_safety"
module ActionView
2018-09-06 13:00:20 -04:00
# 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"
#
2011-04-16 05:42:02 -04:00
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
2011-04-16 05:42:02 -04:00
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
2011-06-05 11:34:40 -04:00
def html_safe
self
end
end
2011-06-05 11:34:40 -04:00
end