Initialize memo pointer and use it consistently to silence gcc 7+
This commit is contained in:
parent
32bec658c1
commit
b6e6807993
10
array.c
10
array.c
@ -6931,7 +6931,7 @@ flatten(VALUE ary, int level)
|
|||||||
{
|
{
|
||||||
long i;
|
long i;
|
||||||
VALUE stack, result, tmp = 0, elt, vmemo;
|
VALUE stack, result, tmp = 0, elt, vmemo;
|
||||||
st_table *memo;
|
st_table *memo = 0;
|
||||||
st_data_t id;
|
st_data_t id;
|
||||||
|
|
||||||
for (i = 0; i < RARRAY_LEN(ary); i++) {
|
for (i = 0; i < RARRAY_LEN(ary); i++) {
|
||||||
@ -6974,7 +6974,7 @@ flatten(VALUE ary, int level)
|
|||||||
}
|
}
|
||||||
tmp = rb_check_array_type(elt);
|
tmp = rb_check_array_type(elt);
|
||||||
if (RBASIC(result)->klass) {
|
if (RBASIC(result)->klass) {
|
||||||
if (level < 0) {
|
if (memo) {
|
||||||
RB_GC_GUARD(vmemo);
|
RB_GC_GUARD(vmemo);
|
||||||
st_clear(memo);
|
st_clear(memo);
|
||||||
}
|
}
|
||||||
@ -6984,7 +6984,7 @@ flatten(VALUE ary, int level)
|
|||||||
rb_ary_push(result, elt);
|
rb_ary_push(result, elt);
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
if (level < 0) {
|
if (memo) {
|
||||||
id = (st_data_t)tmp;
|
id = (st_data_t)tmp;
|
||||||
if (st_is_member(memo, id)) {
|
if (st_is_member(memo, id)) {
|
||||||
st_clear(memo);
|
st_clear(memo);
|
||||||
@ -7001,7 +7001,7 @@ flatten(VALUE ary, int level)
|
|||||||
if (RARRAY_LEN(stack) == 0) {
|
if (RARRAY_LEN(stack) == 0) {
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
if (level < 0) {
|
if (memo) {
|
||||||
id = (st_data_t)ary;
|
id = (st_data_t)ary;
|
||||||
st_delete(memo, &id, 0);
|
st_delete(memo, &id, 0);
|
||||||
}
|
}
|
||||||
@ -7010,7 +7010,7 @@ flatten(VALUE ary, int level)
|
|||||||
ary = rb_ary_pop(stack);
|
ary = rb_ary_pop(stack);
|
||||||
}
|
}
|
||||||
|
|
||||||
if (level < 0) {
|
if (memo) {
|
||||||
st_clear(memo);
|
st_clear(memo);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user