From d620b0b9cdbca58e45033d0eaf4c14192f75f016 Mon Sep 17 00:00:00 2001 From: akr Date: Thu, 1 Aug 2013 12:05:04 +0000 Subject: [PATCH] * bignum.c (rb_big2str1): Raise an error for too big number. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@42307 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ChangeLog | 4 ++++ bignum.c | 4 ++++ 2 files changed, 8 insertions(+) diff --git a/ChangeLog b/ChangeLog index 7acde96a5c..ab05bc93ec 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,7 @@ +Thu Aug 1 21:02:48 2013 Tanaka Akira + + * bignum.c (rb_big2str1): Raise an error for too big number. + Thu Aug 1 20:46:29 2013 Tanaka Akira * bignum.c (power_cache_get_power): Hide cached Bignum objects. diff --git a/bignum.c b/bignum.c index c8de1fa74f..1bde7dab6e 100644 --- a/bignum.c +++ b/bignum.c @@ -4366,6 +4366,10 @@ rb_big2str1(VALUE x, int base) if (base < 2 || 36 < base) rb_raise(rb_eArgError, "invalid radix %d", base); + if (RBIGNUM_LEN(x) >= LONG_MAX/BITSPERDIG) { + rb_raise(rb_eRangeError, "bignum too big to convert into `string'"); + } + if (POW2_P(base)) { /* base == 2 || base == 4 || base == 8 || base == 16 || base == 32 */ return big2str_base_powerof2(x, base);