class String unless method_defined?(:at) def at(position) self[position] end end unless method_defined?(:camelize) def camelize(first_letter=:upper) if first_letter != :lower to_s.gsub(/\/(.?)/) { "::#{$1.upcase}" }.gsub(/(?:^|_)(.)/) { $1.upcase } else to_s.first.chr.downcase + camelize(self)[1..-1] end end alias_method :camelcase, :camelize end unless method_defined?(:camelize!) def camelize!(first_letter=:upper) replace(camelize(first_letter)) end alias_method :camelcase!, :camelize! end unless method_defined?(:classify) def classify to_s.sub(/.*\./, "").camelize end end unless method_defined?(:classify!) def classify! replace(classify) end end unless method_defined?(:dasherize) def dasherize gsub(/_/, "-") end end unless method_defined?(:dasherize!) def dasherize! replace(dasherize) end end unless method_defined?(:demodulize) def demodulize to_s.gsub(/^.*::/, "") end end unless method_defined?(:demodulize!) def demodulize! replace(demodulize) end end def domain string = dup string =~ (/^(?:\w+:\/\/)?([^\/?]+)(?:\/|\?|$)/) ? $1 : string end def downcase? downcase == self end def ellipsize(ellipsize_at, options={}) return(self)if size <= ellipsize_at separator = options.fetch(:separator, "...") offset = options.fetch(:offset, 4) "#{self[0,offset]}#{separator}#{self[-offset,offset]}" end unless method_defined?(:exclude?) def exclude?(string) !include?(string) end end unless method_defined?(:first) def first(limit=1) return("") if limit.zero? limit >= size ? self.dup : to(limit - 1) end end unless method_defined?(:from) def from(position) self[position..-1] end end unless method_defined?(:humanize) def humanize(options = {}) underscore. gsub(/_id\z/, ""). tr("_", " "). gsub(/([a-z\d]*)/i) { |s| s.downcase }. gsub(/\A\w/) { |s| options.fetch(:capitalize, true) ? s.upcase : s } end end unless method_defined?(:humanize!) def humanize!(options={}) replace(humanize(options)) end end unless method_defined?(:indent!) def indent(amount, indent_string=nil, indent_empty_lines=false) indent_string = indent_string || self[/^[ \t]/] || " " substitutes = indent_empty_lines ? /^/ : /^(?!$)/ gsub(substitutes, indent_string * amount) end end unless method_defined?(:indent!) def indent!(amount, indent_string=nil, indent_empty_lines=false) replace(indent(amount, indent_string, indent_empty_lines)) end end unless method_defined?(:last) def last(limit=1) return("") if limit.zero? limit >= size ? self.dup : from(-limit) end end def mixedcase? !upcase? && !downcase? end unless method_defined?(:ordinal) def ordinal to_i.ordinal end end unless method_defined?(:ordinalize) def ordinalize to_i.ordinalize end end unless method_defined?(:parameterize) def parameterize(sep="-") underscore. gsub(/\s+/, "_"). gsub("_", sep). downcase end end unless method_defined?(:parameterize!) def parameterize!(sep="-") replace(parameterize(sep)) end end def pollute(delimiter="^--^--^") split('').map { |c| "#{c}#{delimiter}" }.join end unless method_defined?(:remove) def remove(*patterns) string = dup patterns.each do |pattern| string.gsub!(pattern, "") end string end end unless method_defined?(:remove!) def remove!(*patterns) replace(remove(*patterns)) end end def remove_tags gsub(/<\/?[^>]*>/, "") end def remove_tags! replace(remove_tags) end def shift(*patterns) string = dup patterns.each do |pattern| string.sub!(pattern, "") end string end def shift!(*patterns) replace(shift(*patterns)) end def slugify gsub(/[^\x00-\x7F]+/, ''). gsub(/[^\w_ \-]+/i, ''). gsub(/[ \-]+/i, '-'). gsub(/^\-|\-$/i, ''). downcase end def slugify! replace(slugify) end unless method_defined?(:squish) def squish strip.gsub(/\s+/, ' ') end end unless method_defined?(:squish!) def squish! replace(squish) end end unless method_defined?(:titleize) def titleize underscore. humanize. gsub(/\b(? truncate_at omission = options.fetch(:omission, "...") length_with_room_for_omission = truncate_at - omission.length stop = if options.fetch(:separator, false) rindex(options.fetch(:separator, ''), length_with_room_for_omission) || length_with_room_for_omission else length_with_room_for_omission end "#{self[0, stop]}#{omission}" end end unless method_defined?(:truncate_words) def truncate_words(words_count, options={}) sep = options[:separator] || /\s+/ sep = Regexp.escape(sep.to_s) unless Regexp === sep if self =~ /\A((?:.+?#{sep}){#{words_count - 1}}.+?)#{sep}.*/m $1 + (options[:omission] || '...') else dup end end end unless method_defined?(:underscore) def underscore gsub(/::/, '/'). gsub(/([A-Z\d]+)([A-Z][a-z])/,'\1_\2'). gsub(/([a-z\d])([A-Z])/,'\1_\2'). tr("-", "_"). downcase end end unless method_defined?(:underscore!) def underscore! replace(underscore) end end def unpollute(delimiter="^--^--^") gsub(delimiter, "") end def upcase? upcase == self end end