summaryrefslogtreecommitdiffhomepage
path: root/src/numeric.c
diff options
context:
space:
mode:
authorDaniel Bovensiepen <[email protected]>2012-11-19 12:37:18 +0800
committerDaniel Bovensiepen <[email protected]>2012-11-19 12:37:18 +0800
commite246b79cb2b8b87d9c7d87b8832004a39fc5c4d0 (patch)
tree360a42c0127534f1902799e404734c7ca205b39c /src/numeric.c
parentd8234a45759b3bd7b107750fda886cd828b52173 (diff)
parent1b2257c8ff212d1069b00e11a6b91672c9636ecb (diff)
downloadmruby-e246b79cb2b8b87d9c7d87b8832004a39fc5c4d0.tar.gz
mruby-e246b79cb2b8b87d9c7d87b8832004a39fc5c4d0.zip
Merge remote-tracking branch 'upstream/master' into mrbgems
Diffstat (limited to 'src/numeric.c')
-rw-r--r--src/numeric.c8
1 files changed, 4 insertions, 4 deletions
diff --git a/src/numeric.c b/src/numeric.c
index 98a60ed30..8bf2b3382 100644
--- a/src/numeric.c
+++ b/src/numeric.c
@@ -948,7 +948,7 @@ fix_xor(mrb_state *mrb, mrb_value x)
}
static mrb_value
-lshift(mrb_state *mrb, mrb_int val, unsigned long width)
+lshift(mrb_state *mrb, mrb_int val, int width)
{
if (width > (sizeof(mrb_int)*CHAR_BIT-1)) {
mrb_raisef(mrb, E_RANGE_ERROR, "width(%d) > (%d:sizeof(mrb_int)*CHAR_BIT-1)", width,
@@ -959,7 +959,7 @@ lshift(mrb_state *mrb, mrb_int val, unsigned long width)
}
static mrb_value
-rshift(mrb_int val, unsigned long i)
+rshift(mrb_int val, int i)
{
if (i >= sizeof(mrb_int)*CHAR_BIT-1) {
if (val < 0) return mrb_fixnum_value(-1);
@@ -988,7 +988,7 @@ fix_lshift(mrb_state *mrb, mrb_value x)
y = bit_coerce(mrb, y);
width = mrb_fixnum(y);
if (width < 0)
- return rshift(val, (unsigned long)-width);
+ return rshift(val, -width);
return lshift(mrb, val, width);
}
@@ -1012,7 +1012,7 @@ fix_rshift(mrb_state *mrb, mrb_value x)
i = mrb_fixnum(y);
if (i == 0) return x;
if (i < 0)
- return lshift(mrb, val, (unsigned long)-i);
+ return lshift(mrb, val, -i);
return rshift(val, i);
}