summaryrefslogtreecommitdiffstats
path: root/pack.c
diff options
context:
space:
mode:
authormame <mame@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-05-17 17:56:41 +0000
committermame <mame@b2dd03c8-39d4-4d8f-98ff-823fe69b080e>2008-05-17 17:56:41 +0000
commit81ba64bd417da0de8a4e22352e9d536d76419c98 (patch)
tree90f0288ab5d9d74e5a9eda04d0e6e1c43b7b701a /pack.c
parent713f8925b6e7e6f11e16f170c97557880248179f (diff)
downloadruby-81ba64bd417da0de8a4e22352e9d536d76419c98.tar.gz
ruby-81ba64bd417da0de8a4e22352e9d536d76419c98.tar.xz
ruby-81ba64bd417da0de8a4e22352e9d536d76419c98.zip
* pack.c (pack_pack): check errno to detect error of ruby_strtoul.
* pack.c (pack_unpack): ditto. * test/ruby/test_pack.rb: add a test for above. git-svn-id: http://svn.ruby-lang.org/repos/ruby/trunk@16452 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'pack.c')
-rw-r--r--pack.c9
1 files changed, 9 insertions, 0 deletions
diff --git a/pack.c b/pack.c
index c5a5337ea..255f74de8 100644
--- a/pack.c
+++ b/pack.c
@@ -12,6 +12,7 @@
#include "ruby/ruby.h"
#include <sys/types.h>
#include <ctype.h>
+#include <errno.h>
#define SIZE16 2
#define SIZE32 4
@@ -491,7 +492,11 @@ pack_pack(VALUE ary, VALUE fmt)
p++;
}
else if (ISDIGIT(*p)) {
+ errno = 0;
len = STRTOUL(p, (char**)&p, 10);
+ if (errno) {
+ rb_raise(rb_eRangeError, "pack length too big");
+ }
}
else {
len = 1;
@@ -1350,7 +1355,11 @@ pack_unpack(VALUE str, VALUE fmt)
p++;
}
else if (ISDIGIT(*p)) {
+ errno = 0;
len = STRTOUL(p, (char**)&p, 10);
+ if (errno) {
+ rb_raise(rb_eRangeError, "pack length too big");
+ }
}
else {
len = (type != '@');