Padrino::SafeBuffer is based on ActiveSupport::SafeBuffer
# File lib/padrino/safe_buffer.rb, line 43 def initialize(str = "") @html_safe = true super end
# File lib/padrino/safe_buffer.rb, line 70 def %(args) case args when Hash escaped_args = Hash[args.map { |k,arg| [k, html_escape_interpolated_argument(arg)] }] else escaped_args = Array(args).map { |arg| html_escape_interpolated_argument(arg) } end self.class.new(super(escaped_args)) end
# File lib/padrino/safe_buffer.rb, line 66 def +(other) dup.concat(other) end
# File lib/padrino/safe_buffer.rb, line 20 def [](*args) if args.size < 2 super else if html_safe? new_safe_buffer = super if new_safe_buffer new_safe_buffer.instance_variable_set :@html_safe, true end new_safe_buffer else to_str[*args] end end end
# File lib/padrino/safe_buffer.rb, line 53 def clone_empty self[0, 0] end
# File lib/padrino/safe_buffer.rb, line 57 def concat(value) super(html_escape_interpolated_argument(value)) end
# File lib/padrino/safe_buffer.rb, line 93 def encode_with(coder) coder.represent_object nil, to_str end
# File lib/padrino/safe_buffer.rb, line 81 def html_safe? defined?(@html_safe) && @html_safe end
# File lib/padrino/safe_buffer.rb, line 48 def initialize_copy(other) super @html_safe = other.html_safe? end
# File lib/padrino/safe_buffer.rb, line 62 def prepend(value) super(html_escape_interpolated_argument(value)) end
# File lib/padrino/safe_buffer.rb, line 38 def safe_concat(value) raise SafeConcatError unless html_safe? original_concat(value) end
# File lib/padrino/safe_buffer.rb, line 89 def to_param to_str end
# File lib/padrino/safe_buffer.rb, line 85 def to_s self end