aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorAaron Patterson <aaron.patterson@gmail.com>2010-10-22 17:31:28 -0700
committerAaron Patterson <aaron.patterson@gmail.com>2010-10-22 17:31:28 -0700
commita3f96f16f48dcdb8364d941f760c159ee136d36e (patch)
treedd60743e021ecb79e843bcc7879e4bf3668dbfd4
parentcc120473727f285867300ce8637e6e7b54b93e02 (diff)
downloadrails-a3f96f16f48dcdb8364d941f760c159ee136d36e.tar.gz
rails-a3f96f16f48dcdb8364d941f760c159ee136d36e.tar.bz2
rails-a3f96f16f48dcdb8364d941f760c159ee136d36e.zip
save a few method calls
-rw-r--r--activesupport/lib/active_support/multibyte/chars.rb5
1 files changed, 3 insertions, 2 deletions
diff --git a/activesupport/lib/active_support/multibyte/chars.rb b/activesupport/lib/active_support/multibyte/chars.rb
index 0820579bec..f9607f1aaf 100644
--- a/activesupport/lib/active_support/multibyte/chars.rb
+++ b/activesupport/lib/active_support/multibyte/chars.rb
@@ -270,13 +270,14 @@ module ActiveSupport #:nodoc:
@wrapped_string[*args] = replace_by
else
result = Unicode.u_unpack(@wrapped_string)
- if args[0].is_a?(Fixnum)
+ case args.first
+ when Fixnum
raise IndexError, "index #{args[0]} out of string" if args[0] >= result.length
min = args[0]
max = args[1].nil? ? min : (min + args[1] - 1)
range = Range.new(min, max)
replace_by = [replace_by].pack('U') if replace_by.is_a?(Fixnum)
- elsif args.first.is_a?(Range)
+ when Range
raise RangeError, "#{args[0]} out of range" if args[0].min >= result.length
range = args[0]
else