mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
* array.c (rb_ary_permutation): use frozen shared hidden array.
[ruby-dev:31985] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@13668 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
f6a26d06a2
commit
7550659a33
2 changed files with 7 additions and 5 deletions
|
@ -1,10 +1,13 @@
|
|||
Tue Oct 9 21:29:19 2007 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
||||
Tue Oct 9 21:35:28 2007 Nobuyoshi Nakada <nobu@ruby-lang.org>
|
||||
|
||||
* array.c (rb_ary_permutation, rb_ary_combination): missing type
|
||||
names.
|
||||
|
||||
* array.c (rb_ary_permutation): used buffer should be t1.
|
||||
|
||||
* array.c (rb_ary_permutation): use frozen shared hidden array.
|
||||
[ruby-dev:31985]
|
||||
|
||||
Tue Oct 9 16:58:10 2007 Yukihiro Matsumoto <matz@ruby-lang.org>
|
||||
|
||||
* array.c: remove to_a completely.
|
||||
|
|
7
array.c
7
array.c
|
@ -2988,7 +2988,7 @@ permute0(long n, long r, long *p, long index, int *used, VALUE values)
|
|||
/* And yield it to the associated block */
|
||||
VALUE result = rb_ary_new2(r);
|
||||
VALUE *result_array = RARRAY_PTR(result);
|
||||
VALUE *values_array = RARRAY_PTR(values);
|
||||
const VALUE *values_array = RARRAY_PTR(values);
|
||||
|
||||
for (j = 0; j < r; j++) result_array[j] = values_array[p[j]];
|
||||
RARRAY(result)->len = r;
|
||||
|
@ -3044,12 +3044,11 @@ rb_ary_permutation(VALUE ary, VALUE num)
|
|||
long *p = (long*)RSTRING_PTR(t0);
|
||||
volatile VALUE t1 = tmpbuf(n,sizeof(int));
|
||||
int *used = (int*)RSTRING_PTR(t1);
|
||||
|
||||
ary = rb_ary_dup(ary); /* private defensive copy of ary */
|
||||
VALUE ary0 = ary_make_shared(ary); /* private defensive copy of ary */
|
||||
|
||||
for (i = 0; i < n; i++) used[i] = 0; /* initialize array */
|
||||
|
||||
permute0(n,r,p,0,used,ary); /* compute and yield permutations */
|
||||
permute0(n, r, p, 0, used, ary0); /* compute and yield permutations */
|
||||
}
|
||||
return ary;
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue