Class: String
- Defined in:
- lib/lite/ruby/string.rb,
lib/lite/ruby/safe/string.rb
Constant Summary collapse
- TRANSLITERATIONS =
YAML.load_file( File.('formats/string_transliterations.yml', File.dirname(__FILE__)) ).freeze
Instance Method Summary collapse
- #acronym ⇒ Object
- #acronym! ⇒ Object
- #any?(*keys) ⇒ Boolean
- #at(position) ⇒ Object
- #camelize(first_letter = :upper) ⇒ Object (also: #camelcase)
- #camelize!(first_letter = :upper) ⇒ Object (also: #camelcase!)
- #capitalized? ⇒ Boolean
- #classify ⇒ Object
- #classify! ⇒ Object
- #constantize ⇒ Object
- #dasherize ⇒ Object
- #dasherize! ⇒ Object
- #deconstantize ⇒ Object
- #deconstantize! ⇒ Object
- #dedupe(pattern) ⇒ Object
- #dedupe!(pattern) ⇒ Object
- #demodulize ⇒ Object
- #demodulize! ⇒ Object
- #domain ⇒ Object
- #downcase? ⇒ Boolean
- #each_word(&block) ⇒ Object
- #ellipsize(ellipsize_at, options = {}) ⇒ Object
- #first(limit = 1) ⇒ Object
- #format(*args) ⇒ Object
- #fragment ⇒ Object
- #from(position) ⇒ Object
- #headerize ⇒ Object
- #headerize! ⇒ Object
- #host ⇒ Object
- #humanize(capitalize: true) ⇒ Object
- #humanize!(capitalize: true) ⇒ Object
- #indent(amount, seperator = ' ') ⇒ Object
- #indent!(amount, seperator = ' ') ⇒ Object
- #index_all(pattern) ⇒ Object
- #labelize(capitalize: true) ⇒ Object (also: #labelcase)
- #labelize!(capitalize: true) ⇒ Object (also: #labelcase!)
- #last(limit = 1) ⇒ Object
- #lchomp(match) ⇒ Object
- #lchomp!(match) ⇒ Object
- #methodize ⇒ Object
- #methodize! ⇒ Object
- #mixedcase? ⇒ Boolean
- #modulize ⇒ Object
- #modulize! ⇒ Object
- #non_possessive ⇒ Object
- #non_possessive! ⇒ Object
- #ordinal ⇒ Object
- #ordinalize ⇒ Object
- #parameterize(separator: '-') ⇒ Object
- #parameterize!(separator: '-') ⇒ Object
- #path ⇒ Object
- #pathize ⇒ Object
- #pathize! ⇒ Object
- #pollute(delimiter = '^--^--^') ⇒ Object
- #pollute!(delimiter = '^--^--^') ⇒ Object
- #pop ⇒ Object
- #possessive ⇒ Object
- #possessive! ⇒ Object
- #possessive? ⇒ Boolean
- #push(string) ⇒ Object
- #query ⇒ Object
-
#quote(type = :double, amount = nil) ⇒ Object
rubocop:disable Metrics/AbcSize, Metrics/CyclomaticComplexity, Metrics/MethodLength.
-
#quote!(type = :double, amount = nil) ⇒ Object
rubocop:enable Metrics/AbcSize, Metrics/CyclomaticComplexity, Metrics/MethodLength.
- #remove(*patterns) ⇒ Object
- #remove!(*patterns) ⇒ Object
- #remove_tags ⇒ Object
- #remove_tags! ⇒ Object
- #rotate(amount = 1) ⇒ Object
- #rotate!(amount = 1) ⇒ Object
-
#safe_encode(target_encoding, replacement = '') ⇒ Object
rubocop:disable Metrics/MethodLength.
-
#safe_encode!(target_encoding, replacement = '') ⇒ Object
rubocop:enable Metrics/MethodLength.
- #sample(separator = ' ') ⇒ Object
- #sample!(separator = ' ') ⇒ Object
- #scheme ⇒ Object
- #shift(*patterns) ⇒ Object
- #shift!(*patterns) ⇒ Object
- #shuffle(separator = '') ⇒ Object
- #shuffle!(separator = '') ⇒ Object
- #sift(keep) ⇒ Object
- #sift!(keep) ⇒ Object
- #slugify ⇒ Object
- #slugify! ⇒ Object
- #sort ⇒ Object
- #sort! ⇒ Object
- #squish ⇒ Object
- #squish! ⇒ Object
- #titleize ⇒ Object (also: #titlecase)
- #titleize! ⇒ Object (also: #titlecase!)
- #to(position) ⇒ Object
-
#to_time(form = :local) ⇒ Object
(also: #to_t)
rubocop:disable Metrics/AbcSize, Metrics/CyclomaticComplexity rubocop:disable Metrics/MethodLength, Metrics/PerceivedComplexity.
- #transliterize ⇒ Object
- #transliterize! ⇒ Object
-
#truncate(truncate_at, options = {}) ⇒ Object
rubocop:enable Metrics/MethodLength, Metrics/PerceivedComplexity rubocop:enable Metrics/AbcSize, Metrics/CyclomaticComplexity.
- #truncate_words(words_count, options = {}) ⇒ Object
- #underscore ⇒ Object (also: #snakecase)
- #underscore! ⇒ Object (also: #snakecase!)
- #unpollute(delimiter = '^--^--^') ⇒ Object
- #unpollute!(delimiter = '^--^--^') ⇒ Object
- #unquote ⇒ Object
- #unquote! ⇒ Object
- #unshift(*patterns) ⇒ Object
- #unshift!(*patterns) ⇒ Object
- #upcase? ⇒ Boolean
- #variablize ⇒ Object
- #variablize! ⇒ Object
- #words ⇒ Object
- #words_without_punctuation ⇒ Object
Instance Method Details
#acronym ⇒ Object
12 13 14 |
# File 'lib/lite/ruby/string.rb', line 12 def acronym gsub(/(([a-zA-Z0-9])([a-zA-Z0-9])*)./, '\\2') || self end |
#acronym! ⇒ Object
16 17 18 |
# File 'lib/lite/ruby/string.rb', line 16 def acronym! replace(acronym) end |
#any?(*keys) ⇒ Boolean
20 21 22 |
# File 'lib/lite/ruby/string.rb', line 20 def any?(*keys) keys.any? { |key| include?(key) } end |
#at(position) ⇒ Object
5 6 7 |
# File 'lib/lite/ruby/safe/string.rb', line 5 def at(position) self[position] end |
#camelize(first_letter = :upper) ⇒ Object Also known as: camelcase
9 10 11 12 13 14 15 |
# File 'lib/lite/ruby/safe/string.rb', line 9 def camelize(first_letter = :upper) case first_letter when :upper, true then modulize.gsub(/(\A|\s)([a-z])/) { $1 + $2.upcase } when :lower, false then modulize.gsub(/(\A|\s)([A-Z])/) { $1 + $2.downcase } else modulize end end |
#camelize!(first_letter = :upper) ⇒ Object Also known as: camelcase!
24 25 26 |
# File 'lib/lite/ruby/string.rb', line 24 def camelize!(first_letter = :upper) replace(camelize(first_letter)) end |
#capitalized? ⇒ Boolean
28 29 30 |
# File 'lib/lite/ruby/string.rb', line 28 def capitalized? capitalize == self end |
#classify ⇒ Object
17 18 19 20 21 22 |
# File 'lib/lite/ruby/safe/string.rb', line 17 def classify str = dup str.sub!(/.*\./, '') str.camelize! str || self end |
#classify! ⇒ Object
32 33 34 |
# File 'lib/lite/ruby/string.rb', line 32 def classify! replace(classify) end |
#constantize ⇒ Object
24 25 26 |
# File 'lib/lite/ruby/safe/string.rb', line 24 def constantize Object.const_get(camelize) end |
#dasherize ⇒ Object
28 29 30 |
# File 'lib/lite/ruby/safe/string.rb', line 28 def dasherize underscore.tr('_', '-') end |
#dasherize! ⇒ Object
36 37 38 |
# File 'lib/lite/ruby/string.rb', line 36 def dasherize! replace(dasherize) end |
#deconstantize ⇒ Object
32 33 34 |
# File 'lib/lite/ruby/safe/string.rb', line 32 def deconstantize [0, rindex('::') || 0] end |
#deconstantize! ⇒ Object
40 41 42 |
# File 'lib/lite/ruby/string.rb', line 40 def deconstantize! replace(deconstantize) end |
#dedupe(pattern) ⇒ Object
44 45 46 |
# File 'lib/lite/ruby/string.rb', line 44 def dedupe(pattern) dup.dedupe!(pattern) end |
#dedupe!(pattern) ⇒ Object
48 49 50 51 |
# File 'lib/lite/ruby/string.rb', line 48 def dedupe!(pattern) pattern.each_char { |char| gsub!(/#{Regexp.escape(char)}{2,}/, char) } self end |
#demodulize ⇒ Object
36 37 38 |
# File 'lib/lite/ruby/safe/string.rb', line 36 def demodulize gsub(/^.*::/, '') end |
#demodulize! ⇒ Object
53 54 55 |
# File 'lib/lite/ruby/string.rb', line 53 def demodulize! replace(demodulize) end |
#domain ⇒ Object
57 58 59 60 61 62 63 |
# File 'lib/lite/ruby/string.rb', line 57 def domain return if empty? URI.join(self, '/').to_s.chomp('/') rescue URI::BadURIError, URI::InvalidURIError nil end |
#downcase? ⇒ Boolean
65 66 67 |
# File 'lib/lite/ruby/string.rb', line 65 def downcase? downcase == self end |
#each_word(&block) ⇒ Object
69 70 71 |
# File 'lib/lite/ruby/string.rb', line 69 def each_word(&block) words.each(&block) end |
#ellipsize(ellipsize_at, options = {}) ⇒ Object
73 74 75 76 77 78 79 80 |
# File 'lib/lite/ruby/string.rb', line 73 def ellipsize(ellipsize_at, = {}) return self if length <= ellipsize_at separator = [:separator] || '...' offset = [:offset] || 4 "#{self[0, offset]}#{separator}#{self[-offset, offset]}" end |
#first(limit = 1) ⇒ Object
40 41 42 43 44 45 46 47 48 |
# File 'lib/lite/ruby/safe/string.rb', line 40 def first(limit = 1) if limit.zero? '' elsif limit >= length self else to(limit - 1) end end |
#format(*args) ⇒ Object
90 91 92 |
# File 'lib/lite/ruby/string.rb', line 90 def format(*args) super(self, *args.flatten) end |
#fragment ⇒ Object
82 83 84 85 86 87 88 |
# File 'lib/lite/ruby/string.rb', line 82 def fragment return if empty? URI.parse(self).fragment rescue URI::BadURIError, URI::InvalidURIError nil end |
#from(position) ⇒ Object
50 51 52 |
# File 'lib/lite/ruby/safe/string.rb', line 50 def from(position) self[position..-1] end |
#headerize ⇒ Object
94 95 96 |
# File 'lib/lite/ruby/string.rb', line 94 def headerize squish.each_word(&:capitalize!).join(' ') end |
#headerize! ⇒ Object
98 99 100 |
# File 'lib/lite/ruby/string.rb', line 98 def headerize! replace(headerize) end |
#host ⇒ Object
102 103 104 105 106 107 108 |
# File 'lib/lite/ruby/string.rb', line 102 def host return if empty? URI.parse(self).host rescue URI::BadURIError, URI::InvalidURIError nil end |
#humanize(capitalize: true) ⇒ Object
54 55 56 57 58 59 60 61 62 63 |
# File 'lib/lite/ruby/safe/string.rb', line 54 def humanize(capitalize: true) str = dup str.underscore! str.delete_suffix!('_id') str.tr!('_', ' ') str.squish! str.gsub!(/([a-z\d]*)/i, &:downcase) str.gsub!(/\A\w/) { |s| capitalize ? s.upcase : s } str || self end |
#humanize!(capitalize: true) ⇒ Object
110 111 112 |
# File 'lib/lite/ruby/string.rb', line 110 def humanize!(capitalize: true) replace(humanize(capitalize: capitalize)) end |
#indent(amount, seperator = ' ') ⇒ Object
65 66 67 |
# File 'lib/lite/ruby/safe/string.rb', line 65 def indent(amount, seperator = ' ') dup.indent!(amount, seperator) end |
#indent!(amount, seperator = ' ') ⇒ Object
69 70 71 72 73 74 75 |
# File 'lib/lite/ruby/safe/string.rb', line 69 def indent!(amount, seperator = ' ') if amount >= 0 gsub!(/^/, seperator * amount) else gsub!(/^#{Regexp.escape(seperator)}{0,#{-amount}}/, '') end end |
#index_all(pattern) ⇒ Object
114 115 116 117 118 119 120 121 122 123 124 125 126 |
# File 'lib/lite/ruby/string.rb', line 114 def index_all(pattern) pattern = pattern.to_s if pattern.is_a?(Numeric) arr_indexes = [] srch_index = rindex(pattern) while srch_index temp_string = self[0..(srch_index - 1)] arr_indexes << srch_index srch_index = srch_index.zero? ? nil : temp_string.rindex(pattern) end arr_indexes.reverse end |
#labelize(capitalize: true) ⇒ Object Also known as: labelcase
128 129 130 |
# File 'lib/lite/ruby/string.rb', line 128 def labelize(capitalize: true) dup.labelize!(capitalize: capitalize) end |
#labelize!(capitalize: true) ⇒ Object Also known as: labelcase!
132 133 134 135 136 137 138 139 |
# File 'lib/lite/ruby/string.rb', line 132 def labelize!(capitalize: true) underscore! tr!('_', ' ') squish! gsub!(/([a-z\d]*)/i, &:downcase) gsub!(/\A\w/) { |str| capitalize ? str.upcase : str } gsub!(/ id\z/, ' ID') || self end |
#last(limit = 1) ⇒ Object
77 78 79 80 81 82 83 84 85 |
# File 'lib/lite/ruby/safe/string.rb', line 77 def last(limit = 1) if limit.zero? '' elsif limit >= length self else from(-limit) end end |
#lchomp(match) ⇒ Object
141 142 143 |
# File 'lib/lite/ruby/string.rb', line 141 def lchomp(match) dup.lchomp!(match) end |
#lchomp!(match) ⇒ Object
145 146 147 148 149 150 |
# File 'lib/lite/ruby/string.rb', line 145 def lchomp!(match) return self unless index(match) self[0...match.size] = '' self end |
#methodize ⇒ Object
152 153 154 |
# File 'lib/lite/ruby/string.rb', line 152 def methodize dup.methodize! end |
#methodize! ⇒ Object
156 157 158 159 160 161 162 |
# File 'lib/lite/ruby/string.rb', line 156 def methodize! gsub!(/([A-Z]+)([A-Z])/, '\1_\2') gsub!(/([a-z])([A-Z])/, '\1_\2') gsub!('/', '__') gsub!('::', '__') downcase! || self end |
#mixedcase? ⇒ Boolean
175 176 177 |
# File 'lib/lite/ruby/string.rb', line 175 def mixedcase? !upcase? && !downcase? end |
#modulize ⇒ Object
164 165 166 |
# File 'lib/lite/ruby/string.rb', line 164 def modulize dup.modulize! end |
#modulize! ⇒ Object
168 169 170 171 172 173 |
# File 'lib/lite/ruby/string.rb', line 168 def modulize! gsub!(/__(.?)/) { "::#{$1.upcase}" } gsub!(%r{/(.?)}) { "::#{$1.upcase}" } gsub!(/(?:_+|-+)([a-z])/) { $1.upcase } gsub!(/(\A|\s)([a-z])/) { $1 + $2.upcase } || self end |
#non_possessive ⇒ Object
179 180 181 |
# File 'lib/lite/ruby/string.rb', line 179 def non_possessive dup.non_possessive! end |
#non_possessive! ⇒ Object
183 184 185 186 187 |
# File 'lib/lite/ruby/string.rb', line 183 def non_possessive! return self unless possessive? chomp!("'s") || chomp!("'") || self end |
#ordinal ⇒ Object
189 190 191 |
# File 'lib/lite/ruby/string.rb', line 189 def ordinal to_i.ordinal end |
#ordinalize ⇒ Object
193 194 195 |
# File 'lib/lite/ruby/string.rb', line 193 def ordinalize to_i.ordinalize end |
#parameterize(separator: '-') ⇒ Object
87 88 89 90 91 92 93 |
# File 'lib/lite/ruby/safe/string.rb', line 87 def parameterize(separator: '-') str = dup str.underscore! str.gsub!(/\s+/, separator) str.downcase! str || self end |
#parameterize!(separator: '-') ⇒ Object
197 198 199 |
# File 'lib/lite/ruby/string.rb', line 197 def parameterize!(separator: '-') replace(parameterize(separator: separator)) end |
#path ⇒ Object
201 202 203 204 205 206 207 |
# File 'lib/lite/ruby/string.rb', line 201 def path return if empty? URI.parse(self).path rescue URI::BadURIError, URI::InvalidURIError nil end |
#pathize ⇒ Object
209 210 211 |
# File 'lib/lite/ruby/string.rb', line 209 def pathize dup.pathize! end |
#pathize! ⇒ Object
213 214 215 216 217 218 219 220 221 |
# File 'lib/lite/ruby/string.rb', line 213 def pathize! gsub!(/([A-Z]+)([A-Z])/, '\1_\2') gsub!(/([a-z])([A-Z])/, '\1_\2') gsub!('__', '/') gsub!('::', '/') gsub!(/\s+/, '') gsub!(/[?%*:|"<>.]+/, '') downcase! || self end |
#pollute(delimiter = '^--^--^') ⇒ Object
223 224 225 |
# File 'lib/lite/ruby/string.rb', line 223 def pollute(delimiter = '^--^--^') chars.map { |chr| "#{chr}#{delimiter}" }.join end |
#pollute!(delimiter = '^--^--^') ⇒ Object
227 228 229 |
# File 'lib/lite/ruby/string.rb', line 227 def pollute!(delimiter = '^--^--^') replace(pollute(delimiter)) end |
#pop ⇒ Object
231 232 233 |
# File 'lib/lite/ruby/string.rb', line 231 def pop self[-1] end |
#possessive ⇒ Object
235 236 237 238 239 240 |
# File 'lib/lite/ruby/string.rb', line 235 def possessive return self if possessive? possession = end_with?('s') ? "'" : "'s" "#{self}#{possession}" end |
#possessive! ⇒ Object
242 243 244 |
# File 'lib/lite/ruby/string.rb', line 242 def possessive! replace(possessive) end |
#possessive? ⇒ Boolean
246 247 248 |
# File 'lib/lite/ruby/string.rb', line 246 def possessive? %w['s s'].any? { |pos| end_with?(pos) } end |
#push(string) ⇒ Object
250 251 252 |
# File 'lib/lite/ruby/string.rb', line 250 def push(string) replace(concat(string)) end |
#query ⇒ Object
254 255 256 257 258 259 260 |
# File 'lib/lite/ruby/string.rb', line 254 def query return if empty? URI.parse(self).query rescue URI::BadURIError, URI::InvalidURIError nil end |
#quote(type = :double, amount = nil) ⇒ Object
rubocop:disable Metrics/AbcSize, Metrics/CyclomaticComplexity, Metrics/MethodLength
263 264 265 266 267 268 269 270 271 272 273 274 275 276 277 278 279 280 281 282 283 284 285 286 287 288 289 290 291 292 293 294 295 296 297 298 299 |
# File 'lib/lite/ruby/string.rb', line 263 def quote(type = :double, amount = nil) if type.is_a?(Integer) tmp = amount amount = type type = tmp || :mixed else amount ||= 1 end case type.to_s when "'", 'single', 's', '1' f = "'" * amount b = f when '"', 'double', 'd', '2' f = '"' * amount b = f when '`', 'back', 'backtick', 'b', '-1' f = '`' * amount b = f when "`'", 'bracket', 'sb' f = '`' * amount b = "'" * amount when "'\"", 'mixed', 'm', 'Integer' c = (amount.to_f / 2).to_i f = '"' * c b = f if amount.odd? f = "'#{f}" b += "'" end else raise ArgumentError, "Invalid quote type: #{type.inspect}" end "#{f}#{self}#{b}" end |
#quote!(type = :double, amount = nil) ⇒ Object
rubocop:enable Metrics/AbcSize, Metrics/CyclomaticComplexity, Metrics/MethodLength
302 303 304 |
# File 'lib/lite/ruby/string.rb', line 302 def quote!(type = :double, amount = nil) replace(quote(type, amount)) end |
#remove(*patterns) ⇒ Object
95 96 97 |
# File 'lib/lite/ruby/safe/string.rb', line 95 def remove(*patterns) dup.remove!(*patterns) end |
#remove!(*patterns) ⇒ Object
99 100 101 102 103 |
# File 'lib/lite/ruby/safe/string.rb', line 99 def remove!(*patterns) patterns.each_with_object(self) do |pat, str| pat.is_a?(Range) ? str.slice!(pat) : str.gsub!(pat, '') end end |
#remove_tags ⇒ Object
306 307 308 |
# File 'lib/lite/ruby/string.rb', line 306 def dup. end |
#remove_tags! ⇒ Object
310 311 312 |
# File 'lib/lite/ruby/string.rb', line 310 def gsub!(%r{</?[^>]*>}, '') || self end |
#rotate(amount = 1) ⇒ Object
314 315 316 |
# File 'lib/lite/ruby/string.rb', line 314 def rotate(amount = 1) dup.rotate!(amount) end |
#rotate!(amount = 1) ⇒ Object
318 319 320 321 |
# File 'lib/lite/ruby/string.rb', line 318 def rotate!(amount = 1) amount += size if amount.negative? slice!(amount, size - amount) + slice!(0, amount) end |
#safe_encode(target_encoding, replacement = '') ⇒ Object
rubocop:disable Metrics/MethodLength
324 325 326 327 328 329 330 331 332 333 334 335 336 |
# File 'lib/lite/ruby/string.rb', line 324 def safe_encode(target_encoding, replacement = '') encode(target_encoding) rescue Encoding::InvalidByteSequenceError force_encoding(target_encoding).scrub!(replacement) rescue Encoding::UndefinedConversionError encode( target_encoding, invalid: :replace, undef: :replace, replace: replacement, UNIVERSAL_NEWLINE_DECORATOR: true ) end |
#safe_encode!(target_encoding, replacement = '') ⇒ Object
rubocop:enable Metrics/MethodLength
339 340 341 |
# File 'lib/lite/ruby/string.rb', line 339 def safe_encode!(target_encoding, replacement = '') replace(safe_encode(target_encoding, replacement)) end |
#sample(separator = ' ') ⇒ Object
343 344 345 |
# File 'lib/lite/ruby/string.rb', line 343 def sample(separator = ' ') split(separator).sample end |
#sample!(separator = ' ') ⇒ Object
347 348 349 |
# File 'lib/lite/ruby/string.rb', line 347 def sample!(separator = ' ') replace(sample(separator)) end |
#scheme ⇒ Object
351 352 353 354 355 356 357 |
# File 'lib/lite/ruby/string.rb', line 351 def scheme return if empty? URI.parse(self).scheme rescue URI::BadURIError, URI::InvalidURIError nil end |
#shift(*patterns) ⇒ Object
359 360 361 |
# File 'lib/lite/ruby/string.rb', line 359 def shift(*patterns) dup.shift!(*patterns) end |
#shift!(*patterns) ⇒ Object
363 364 365 366 367 |
# File 'lib/lite/ruby/string.rb', line 363 def shift!(*patterns) return self[0] if patterns.empty? patterns.each_with_object(self) { |pat, str| str.sub!(pat, '') } end |
#shuffle(separator = '') ⇒ Object
369 370 371 |
# File 'lib/lite/ruby/string.rb', line 369 def shuffle(separator = '') split(separator).shuffle.join end |
#shuffle!(separator = '') ⇒ Object
373 374 375 |
# File 'lib/lite/ruby/string.rb', line 373 def shuffle!(separator = '') replace(shuffle(separator)) end |
#sift(keep) ⇒ Object
377 378 379 380 381 382 383 384 385 386 |
# File 'lib/lite/ruby/string.rb', line 377 def sift(keep) keep = case keep when String then keep.chars when Array then keep.map(&:to_s) when Range then keep.to_a.map(&:to_s) else raise TypeError, "Invalid parameter: #{keep.inspect}" end chars.keep_if { |chr| keep.include?(chr) }.join end |
#sift!(keep) ⇒ Object
388 389 390 |
# File 'lib/lite/ruby/string.rb', line 388 def sift!(keep) replace(sift(keep)) end |
#slugify ⇒ Object
392 393 394 |
# File 'lib/lite/ruby/string.rb', line 392 def slugify dup.slugify! end |
#slugify! ⇒ Object
396 397 398 399 400 401 402 |
# File 'lib/lite/ruby/string.rb', line 396 def slugify! gsub!(/[^\x00-\x7F]+/, '') gsub!(/[^\w \-]+/i, '') gsub!(/[ \-]+/i, '-') gsub!(/^-|-$/i, '') downcase! || self end |
#sort ⇒ Object
404 405 406 |
# File 'lib/lite/ruby/string.rb', line 404 def sort chars.sort.join end |
#sort! ⇒ Object
408 409 410 |
# File 'lib/lite/ruby/string.rb', line 408 def sort! replace(sort) end |
#squish ⇒ Object
105 106 107 |
# File 'lib/lite/ruby/safe/string.rb', line 105 def squish dup.squish! end |
#squish! ⇒ Object
109 110 111 112 |
# File 'lib/lite/ruby/safe/string.rb', line 109 def squish! strip! gsub!(/\s+/, ' ') || self end |
#titleize ⇒ Object Also known as: titlecase
114 115 116 117 118 119 120 |
# File 'lib/lite/ruby/safe/string.rb', line 114 def titleize str = dup str.underscore! str.humanize! str.gsub!(/\b(?<!['’`])[a-z]/) { $&.capitalize } str || self end |
#titleize! ⇒ Object Also known as: titlecase!
420 421 422 |
# File 'lib/lite/ruby/string.rb', line 420 def titleize! replace(titleize) end |
#to(position) ⇒ Object
122 123 124 |
# File 'lib/lite/ruby/safe/string.rb', line 122 def to(position) self[0..position] end |
#to_time(form = :local) ⇒ Object Also known as: to_t
rubocop:disable Metrics/AbcSize, Metrics/CyclomaticComplexity rubocop:disable Metrics/MethodLength, Metrics/PerceivedComplexity
128 129 130 131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 |
# File 'lib/lite/ruby/safe/string.rb', line 128 def to_time(form = :local) parts = Date.parse(self, false) used_keys = %i[year mon mday hour min sec sec_fraction offset] return if (parts.keys & used_keys).empty? now = Time.now time = Time.new( parts[:year] || now.year, parts[:mon] || now.month, parts[:mday] || now.day, parts[:hour] || 0, parts[:min] || 0, (parts[:sec] || 0) + (parts[:sec_fraction] || 0), parts[:offset] || (form == :utc ? 0 : nil) ) form == :utc ? time.utc : time.to_time end |
#transliterize ⇒ Object
412 413 414 |
# File 'lib/lite/ruby/string.rb', line 412 def transliterize TRANSLITERATIONS.each_with_object(dup) { |(k, v), s| s.gsub!(k, v) } end |
#transliterize! ⇒ Object
416 417 418 |
# File 'lib/lite/ruby/string.rb', line 416 def transliterize! replace(transliterize) end |
#truncate(truncate_at, options = {}) ⇒ Object
rubocop:enable Metrics/MethodLength, Metrics/PerceivedComplexity rubocop:enable Metrics/AbcSize, Metrics/CyclomaticComplexity
149 150 151 152 153 154 155 156 157 |
# File 'lib/lite/ruby/safe/string.rb', line 149 def truncate(truncate_at, = {}) return self unless length > truncate_at omission = [:omission] || '...' seperator = [:separator] size_with_room_for_omission = truncate_at - omission.length stop = rindex(seperator || '', size_with_room_for_omission) if seperator "#{self[0, stop || size_with_room_for_omission]}#{omission}" end |
#truncate_words(words_count, options = {}) ⇒ Object
159 160 161 162 163 164 165 |
# File 'lib/lite/ruby/safe/string.rb', line 159 def truncate_words(words_count, = {}) sep = [:separator] || /\s+/ sep = Regexp.escape(sep.to_s) unless sep.is_a?(Regexp) return dup unless self =~ /\A((?>.+?#{sep}){#{words_count - 1}}.+?)#{sep}.*/m $1 + ([:omission] || '...') end |
#underscore ⇒ Object Also known as: snakecase
167 168 169 170 171 172 173 174 175 176 |
# File 'lib/lite/ruby/safe/string.rb', line 167 def underscore str = dup str.camelize! str.gsub!(/::/, '/') str.gsub!(/([A-Z\d]+)([A-Z][a-z])/, '\1_\2') str.gsub!(/([a-z\d])([A-Z])/, '\1_\2') str.tr!('-', '_') str.downcase! str || self end |
#underscore! ⇒ Object Also known as: snakecase!
428 429 430 |
# File 'lib/lite/ruby/string.rb', line 428 def underscore! replace(underscore) end |
#unpollute(delimiter = '^--^--^') ⇒ Object
432 433 434 |
# File 'lib/lite/ruby/string.rb', line 432 def unpollute(delimiter = '^--^--^') dup.unpollute!(delimiter) end |
#unpollute!(delimiter = '^--^--^') ⇒ Object
436 437 438 |
# File 'lib/lite/ruby/string.rb', line 436 def unpollute!(delimiter = '^--^--^') gsub!(delimiter, '') || self end |
#unquote ⇒ Object
440 441 442 |
# File 'lib/lite/ruby/string.rb', line 440 def unquote dup.unquote! end |
#unquote! ⇒ Object
444 445 446 447 448 449 450 451 452 |
# File 'lib/lite/ruby/string.rb', line 444 def unquote! [0, -1].each do |i| case self[i, 1] when "'", '"', '`' then self[i] = '' end end self end |
#unshift(*patterns) ⇒ Object
454 455 456 457 |
# File 'lib/lite/ruby/string.rb', line 454 def unshift(*patterns) patterns.each_with_object('') { |pat, str| str << pat } .concat(self) end |
#unshift!(*patterns) ⇒ Object
459 460 461 |
# File 'lib/lite/ruby/string.rb', line 459 def unshift!(*patterns) replace(unshift(*patterns)) end |
#upcase? ⇒ Boolean
424 425 426 |
# File 'lib/lite/ruby/string.rb', line 424 def upcase? upcase == self end |
#variablize ⇒ Object
476 477 478 |
# File 'lib/lite/ruby/string.rb', line 476 def variablize "@#{gsub(/\W/, '_')}" end |
#variablize! ⇒ Object
480 481 482 |
# File 'lib/lite/ruby/string.rb', line 480 def variablize! replace(variablize) end |
#words ⇒ Object
463 464 465 |
# File 'lib/lite/ruby/string.rb', line 463 def words split(/\s+/) end |
#words_without_punctuation ⇒ Object
467 468 469 470 471 472 473 474 |
# File 'lib/lite/ruby/string.rb', line 467 def words_without_punctuation str = dup str.gsub!(%r{[.?¿¡…!,::;—"。?!、‘“”„«»〈〉《》,/\[\]]}, ' ') str.gsub!('- ', ' ') str.squeeze!(' ') str.strip! str.words end |