mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
rational.c: memory leak in gcd
* rational.c (rb_gcd_gmp): fix memory leak. patched by KISHIMOTO, Makoto <ksmakoto AT dd.iij4u.or.jp> in [ruby-dev:49934]. [Bug #13089] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@57236 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
c922626aba
commit
994d13b98f
2 changed files with 15 additions and 0 deletions
|
@ -261,10 +261,15 @@ rb_gcd_gmp(VALUE x, VALUE y)
|
|||
|
||||
mpz_gcd(mz, mx, my);
|
||||
|
||||
mpz_clear(mx);
|
||||
mpz_clear(my);
|
||||
|
||||
zn = (mpz_sizeinbase(mz, 16) + SIZEOF_BDIGIT*2 - 1) / (SIZEOF_BDIGIT*2);
|
||||
z = rb_big_new(zn, 1);
|
||||
mpz_export(BIGNUM_DIGITS(z), &count, -1, sizeof(BDIGIT), 0, nails, mz);
|
||||
|
||||
mpz_clear(mz);
|
||||
|
||||
return rb_big_norm(z);
|
||||
}
|
||||
#endif
|
||||
|
|
|
@ -880,6 +880,16 @@ class Rational_Test < Test::Unit::TestCase
|
|||
assert_equal(1152921470247108503, 1073741789.lcm(1073741827))
|
||||
end
|
||||
|
||||
def test_gcd_no_memory_leak
|
||||
assert_no_memory_leak([], "#{<<-"begin;"}", "#{<<-"end;"}", limit: 1.2, rss: true)
|
||||
x = (1<<121) + 1
|
||||
y = (1<<99) + 1
|
||||
1000.times{x.gcd(y)}
|
||||
begin;
|
||||
100.times {1000.times{x.gcd(y)}}
|
||||
end;
|
||||
end
|
||||
|
||||
def test_supp
|
||||
assert_predicate(1, :real?)
|
||||
assert_predicate(1.1, :real?)
|
||||
|
|
Loading…
Reference in a new issue