Class: ActiveSupport::SafeBuffer

Inherits:
String show all
Defined in:
activesupport/lib/active_support/core_ext/string/output_safety.rb

Direct Known Subclasses

ActionView::OutputBuffer

Defined Under Namespace

Classes: SafeConcatError

Constant Summary collapse

UNSAFE_STRING_METHODS =
%w(
capitalize chomp chop delete downcase gsub lstrip next reverse rstrip
slice squeeze strip sub succ swapcase tr tr_s upcase prepend

Constants inherited from String

String::BLANK_RE

Instance Method Summary collapse

Methods inherited from String

#acts_like_string?, #as_json, #at, #blank?, #camelize, #classify, #constantize, #dasherize, #deconstantize, #demodulize, #exclude?, #first, #foreign_key, #from, #html_safe, #humanize, #in_time_zone, #indent, #indent!, #inquiry, #is_utf8?, #last, #mb_chars, #parameterize, #pluralize, #remove, #remove!, #safe_constantize, #singularize, #squish, #squish!, #strip_heredoc, #tableize, #titleize, #to, #to_date, #to_datetime, #to_time, #truncate, #underscore

Constructor Details

#initializeSafeBuffer

Returns a new instance of SafeBuffer.



158
159
160
161
# File 'activesupport/lib/active_support/core_ext/string/output_safety.rb', line 158

def initialize(*)
  @html_safe = true
  super
end

Instance Method Details

#%(args) ⇒ Object



185
186
187
188
189
190
191
192
193
194
# File 'activesupport/lib/active_support/core_ext/string/output_safety.rb', line 185

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

#+(other) ⇒ Object



181
182
183
# File 'activesupport/lib/active_support/core_ext/string/output_safety.rb', line 181

def +(other)
  dup.concat(other)
end

#[](*args) ⇒ Object



139
140
141
142
143
144
145
146
147
148
149
150
151
# File 'activesupport/lib/active_support/core_ext/string/output_safety.rb', line 139

def [](*args)
  if args.size < 2
    super
  else
    if html_safe?
      new_safe_buffer = super
      new_safe_buffer.instance_eval { @html_safe = true }
      new_safe_buffer
    else
      to_str[*args]
    end
  end
end

#clone_emptyObject



168
169
170
# File 'activesupport/lib/active_support/core_ext/string/output_safety.rb', line 168

def clone_empty
  self[0, 0]
end

#concat(value) ⇒ Object Also known as: <<



172
173
174
175
176
177
178
# File 'activesupport/lib/active_support/core_ext/string/output_safety.rb', line 172

def concat(value)
  if !html_safe? || value.html_safe?
    super(value)
  else
    super(ERB::Util.h(value))
  end
end

#encode_with(coder) ⇒ Object



208
209
210
# File 'activesupport/lib/active_support/core_ext/string/output_safety.rb', line 208

def encode_with(coder)
  coder.represent_scalar nil, to_str
end

#html_safe?Boolean

Returns:

  • (Boolean)


196
197
198
# File 'activesupport/lib/active_support/core_ext/string/output_safety.rb', line 196

def html_safe?
  defined?(@html_safe) && @html_safe
end

#initialize_copy(other) ⇒ Object



163
164
165
166
# File 'activesupport/lib/active_support/core_ext/string/output_safety.rb', line 163

def initialize_copy(other)
  super
  @html_safe = other.html_safe?
end

#safe_concat(value) ⇒ Object

Raises:



153
154
155
156
# File 'activesupport/lib/active_support/core_ext/string/output_safety.rb', line 153

def safe_concat(value)
  raise SafeConcatError unless html_safe?
  original_concat(value)
end

#to_paramObject



204
205
206
# File 'activesupport/lib/active_support/core_ext/string/output_safety.rb', line 204

def to_param
  to_str
end

#to_sObject



200
201
202
# File 'activesupport/lib/active_support/core_ext/string/output_safety.rb', line 200

def to_s
  self
end