Class: ActiveSupport::SafeBuffer

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

Defined Under Namespace

Classes: SafeConcatError

Constant Summary collapse

UNSAFE_STRING_METHODS =
%w(
  capitalize chomp chop delete delete_prefix delete_suffix
  downcase lstrip next reverse rstrip scrub slice squeeze strip
  succ swapcase tr tr_s unicode_normalize upcase
)
UNSAFE_STRING_METHODS_WITH_BACKREF =
%w(gsub sub)

Constants inherited from String

String::BLANK_RE, String::ENCODED_BLANKS

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, #truncate_bytes, #truncate_words, #underscore, #upcase_first

Constructor Details

#initialize(str = "") ⇒ SafeBuffer

Returns a new instance of SafeBuffer.



201
202
203
204
# File 'lib/active_support/core_ext/string/output_safety.rb', line 201

def initialize(str = "")
  @html_safe = true
  super
end

Instance Method Details

#%(args) ⇒ Object



251
252
253
254
255
256
257
258
259
260
# File 'lib/active_support/core_ext/string/output_safety.rb', line 251

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

#*Object



244
245
246
247
248
249
# File 'lib/active_support/core_ext/string/output_safety.rb', line 244

def *(*)
  new_string = super
  new_safe_buffer = new_string.is_a?(SafeBuffer) ? new_string : SafeBuffer.new(new_string)
  new_safe_buffer.instance_variable_set(:@html_safe, @html_safe)
  new_safe_buffer
end

#+(other) ⇒ Object



240
241
242
# File 'lib/active_support/core_ext/string/output_safety.rb', line 240

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

#[](*args) ⇒ Object



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

def [](*args)
  if html_safe?
    new_string = super

    return unless new_string

    new_safe_buffer = new_string.is_a?(SafeBuffer) ? new_string : SafeBuffer.new(new_string)
    new_safe_buffer.instance_variable_set :@html_safe, true
    new_safe_buffer
  else
    to_str[*args]
  end
end

#[]=(*args) ⇒ Object



232
233
234
235
236
237
238
# File 'lib/active_support/core_ext/string/output_safety.rb', line 232

def []=(*args)
  if args.count == 3
    super(args[0], args[1], html_escape_interpolated_argument(args[2]))
  else
    super(args[0], html_escape_interpolated_argument(args[1]))
  end
end

#clone_emptyObject



211
212
213
# File 'lib/active_support/core_ext/string/output_safety.rb', line 211

def clone_empty
  self[0, 0]
end

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



215
216
217
# File 'lib/active_support/core_ext/string/output_safety.rb', line 215

def concat(value)
  super(html_escape_interpolated_argument(value))
end

#encode_with(coder) ⇒ Object



274
275
276
# File 'lib/active_support/core_ext/string/output_safety.rb', line 274

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

#html_safe?Boolean

Returns:

  • (Boolean)


262
263
264
# File 'lib/active_support/core_ext/string/output_safety.rb', line 262

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

#initialize_copy(other) ⇒ Object



206
207
208
209
# File 'lib/active_support/core_ext/string/output_safety.rb', line 206

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

#insert(index, value) ⇒ Object



220
221
222
# File 'lib/active_support/core_ext/string/output_safety.rb', line 220

def insert(index, value)
  super(index, html_escape_interpolated_argument(value))
end

#prepend(value) ⇒ Object



224
225
226
# File 'lib/active_support/core_ext/string/output_safety.rb', line 224

def prepend(value)
  super(html_escape_interpolated_argument(value))
end

#replace(value) ⇒ Object



228
229
230
# File 'lib/active_support/core_ext/string/output_safety.rb', line 228

def replace(value)
  super(html_escape_interpolated_argument(value))
end

#safe_concat(value) ⇒ Object

Raises:



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

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

#to_paramObject



270
271
272
# File 'lib/active_support/core_ext/string/output_safety.rb', line 270

def to_param
  to_str
end

#to_sObject



266
267
268
# File 'lib/active_support/core_ext/string/output_safety.rb', line 266

def to_s
  self
end