[前][次][番号順一覧][スレッド一覧]

ruby-changes:49831

From: shyouhei <ko1@a...>
Date: Fri, 19 Jan 2018 17:18:05 +0900 (JST)
Subject: [ruby-changes:49831] shyouhei:r61949 (trunk): don't abuse RSTRING_PTR (2nd try)

shyouhei	2018-01-19 17:17:56 +0900 (Fri, 19 Jan 2018)

  New Revision: 61949

  https://svn.ruby-lang.org/cgi-bin/viewvc.cgi?view=revision&revision=61949

  Log:
    don't abuse RSTRING_PTR (2nd try)
    
    r61827, r61947 was about to fix this. The proper way to allocate
    memory region is called ALLOCV_N.

  Modified files:
    trunk/array.c
Index: array.c
===================================================================
--- array.c	(revision 61948)
+++ array.c	(revision 61949)
@@ -5064,8 +5064,6 @@ rb_ary_cycle(int argc, VALUE *argv, VALU https://github.com/ruby/ruby/blob/trunk/array.c#L5064
     return Qnil;
 }
 
-#define tmpbuf(n, size) rb_str_tmp_new((n)*(size))
-#define tmpbuf_discard(s) (rb_str_resize((s), 0L), RBASIC_SET_CLASS_RAW(s, rb_cString))
 #define tmpary(n) rb_ary_tmp_new(n)
 #define tmpary_discard(a) (ary_discard(a), RBASIC_SET_CLASS_RAW(a, rb_cArray))
 
@@ -5568,15 +5566,14 @@ rb_ary_product(int argc, VALUE *argv, VA https://github.com/ruby/ruby/blob/trunk/array.c#L5566
 {
     int n = argc+1;    /* How many arrays we're operating on */
     volatile VALUE t0 = tmpary(n);
-    volatile VALUE t1 = tmpbuf(n, sizeof(int));
+    volatile VALUE t1 = Qundef;
     VALUE *arrays = RARRAY_PTR(t0); /* The arrays we're computing the product of */
-    int *counters = (int*)RSTRING_PTR(t1); /* The current position in each one */
+    int *counters = ALLOCV_N(int, t1, n); /* The current position in each one */
     VALUE result = Qnil;      /* The array we'll be returning, when no block given */
     long i,j;
     long resultlen = 1;
 
     RBASIC_CLEAR_CLASS(t0);
-    RBASIC_CLEAR_CLASS(t1);
 
     /* initialize the arrays of arrays */
     ARY_SET_LEN(t0, n);
@@ -5647,7 +5644,7 @@ rb_ary_product(int argc, VALUE *argv, VA https://github.com/ruby/ruby/blob/trunk/array.c#L5644
     }
 done:
     tmpary_discard(t0);
-    tmpbuf_discard(t1);
+    ALLOCV_END(t1);
 
     return NIL_P(result) ? ary : result;
 }

--
ML: ruby-changes@q...
Info: http://www.atdot.net/~ko1/quickml/

[前][次][番号順一覧][スレッド一覧]