From 9de7bcff88b3337a76bd21c6552f39cd4c12115f Mon Sep 17 00:00:00 2001 From: mame Date: Thu, 31 Jul 2008 13:18:10 +0000 Subject: [PATCH] * ext/bigdecimal/bigdecimal.c (VpMult): prevent memory leak. git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@18296 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ChangeLog | 4 ++++ ext/bigdecimal/bigdecimal.c | 5 ++++- 2 files changed, 8 insertions(+), 1 deletion(-) diff --git a/ChangeLog b/ChangeLog index 0ec114d09e..4b30b59370 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,7 @@ +Thu Jul 31 22:17:35 2008 Yusuke Endoh + + * ext/bigdecimal/bigdecimal.c (VpMult): prevent memory leak. + Thu Jul 31 20:05:56 2008 NARUSE, Yui * test/ruby/test_transcode.rb (test_unicode_public_review_issue_121): diff --git a/ext/bigdecimal/bigdecimal.c b/ext/bigdecimal/bigdecimal.c index 51bd6447ff..2498ea4450 100644 --- a/ext/bigdecimal/bigdecimal.c +++ b/ext/bigdecimal/bigdecimal.c @@ -3164,7 +3164,10 @@ VpMult(Real *c, Real *a, Real *b) /* set LHSV c info */ c->exponent = a->exponent; /* set exponent */ - if(!AddExponent(c,b->exponent)) return 0; + if(!AddExponent(c,b->exponent)) { + VpFree(c); + return 0; + } VpSetSign(c,VpGetSign(a)*VpGetSign(b)); /* set sign */ Carry = 0; nc = ind_c = MxIndAB;