diff options
author | shyouhei <shyouhei@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2010-05-28 08:51:41 +0000 |
---|---|---|
committer | shyouhei <shyouhei@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2010-05-28 08:51:41 +0000 |
commit | bcfcbefc2665537f032f08a9ae4b373d1b325e1e (patch) | |
tree | 4d9b92ab4d43cc5cd388d4f8abf8ab6a339c05e6 | |
parent | 006f384f8e33840e555f0776bfd120f1f0dbd20c (diff) |
* array.c (rb_ary_product): Use tmpary instead, to ensure marking
arrays by GC.
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8@28050 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
-rw-r--r-- | ChangeLog | 4 | ||||
-rw-r--r-- | array.c | 4 |
2 files changed, 6 insertions, 2 deletions
@@ -1,3 +1,7 @@ +Fri May 28 17:34:48 2010 URABE Shyouhei <[email protected]> + + * array.c (rb_ary_product): Ensure arrays to be marked by GC. + Fri May 28 10:40:37 2010 Nobuyoshi Nakada <[email protected]> * lib/mkmf.rb (checking_for): ignore toplevel. @@ -3683,9 +3683,9 @@ rb_ary_product(argc, argv, ary) VALUE ary; { int n = argc+1; /* How many arrays we're operating on */ - volatile VALUE t0 = tmpbuf(n, sizeof(VALUE)); + volatile VALUE t0 = ary_new(0, n); volatile VALUE t1 = tmpbuf(n, sizeof(int)); - VALUE *arrays = (VALUE*)RSTRING(t0)->ptr; /* The arrays we're computing the product of */ + VALUE *arrays = RARRAY(t0)->ptr; /* The arrays we're computing the product of */ int *counters = (int*)RSTRING(t1)->ptr; /* The current position in each one */ VALUE result; /* The array we'll be returning */ long i,j; |