From 8db269edb3550a85dfab9b193ea115ca36912ced Mon Sep 17 00:00:00 2001 From: Aaron Patterson <tenderlove@ruby-lang.org> Date: Tue, 31 Aug 2021 16:58:29 -0700 Subject: [PATCH] Guard array when appending This prevents early collection of the array. The GC doesn't see the array on the stack when Ruby is compiled with optimizations enabled Thanks @jhaberman for the test case [ruby-core:105099] [Bug #18140] --- ext/-test-/array/concat/depend | 321 ++++++++++++++++++++++++ ext/-test-/array/concat/extconf.rb | 2 + ext/-test-/array/concat/to_ary_conact.c | 64 +++++ test/-ext-/array/test_to_ary_concat.rb | 20 ++ 4 files changed, 407 insertions(+) create mode 100644 ext/-test-/array/concat/depend create mode 100644 ext/-test-/array/concat/extconf.rb create mode 100644 ext/-test-/array/concat/to_ary_conact.c create mode 100644 test/-ext-/array/test_to_ary_concat.rb diff --git a/ext/-test-/array/concat/depend b/ext/-test-/array/concat/depend new file mode 100644 index 0000000000..ba069376a4 --- /dev/null +++ b/ext/-test-/array/concat/depend @@ -0,0 +1,321 @@ +# AUTOGENERATED DEPENDENCIES START +resize.o: $(RUBY_EXTCONF_H) +resize.o: $(arch_hdrdir)/ruby/config.h +resize.o: $(hdrdir)/ruby/assert.h +resize.o: $(hdrdir)/ruby/backward.h +resize.o: $(hdrdir)/ruby/backward/2/assume.h +resize.o: $(hdrdir)/ruby/backward/2/attributes.h +resize.o: $(hdrdir)/ruby/backward/2/bool.h +resize.o: $(hdrdir)/ruby/backward/2/gcc_version_since.h +resize.o: $(hdrdir)/ruby/backward/2/inttypes.h +resize.o: $(hdrdir)/ruby/backward/2/limits.h +resize.o: $(hdrdir)/ruby/backward/2/long_long.h +resize.o: $(hdrdir)/ruby/backward/2/stdalign.h +resize.o: $(hdrdir)/ruby/backward/2/stdarg.h +resize.o: $(hdrdir)/ruby/defines.h +resize.o: $(hdrdir)/ruby/intern.h +resize.o: $(hdrdir)/ruby/internal/anyargs.h +resize.o: $(hdrdir)/ruby/internal/arithmetic.h +resize.o: $(hdrdir)/ruby/internal/arithmetic/char.h +resize.o: $(hdrdir)/ruby/internal/arithmetic/double.h +resize.o: $(hdrdir)/ruby/internal/arithmetic/fixnum.h +resize.o: $(hdrdir)/ruby/internal/arithmetic/gid_t.h +resize.o: $(hdrdir)/ruby/internal/arithmetic/int.h +resize.o: $(hdrdir)/ruby/internal/arithmetic/intptr_t.h +resize.o: $(hdrdir)/ruby/internal/arithmetic/long.h +resize.o: $(hdrdir)/ruby/internal/arithmetic/long_long.h +resize.o: $(hdrdir)/ruby/internal/arithmetic/mode_t.h +resize.o: $(hdrdir)/ruby/internal/arithmetic/off_t.h +resize.o: $(hdrdir)/ruby/internal/arithmetic/pid_t.h +resize.o: $(hdrdir)/ruby/internal/arithmetic/short.h +resize.o: $(hdrdir)/ruby/internal/arithmetic/size_t.h +resize.o: $(hdrdir)/ruby/internal/arithmetic/st_data_t.h +resize.o: $(hdrdir)/ruby/internal/arithmetic/uid_t.h +resize.o: $(hdrdir)/ruby/internal/assume.h +resize.o: $(hdrdir)/ruby/internal/attr/alloc_size.h +resize.o: $(hdrdir)/ruby/internal/attr/artificial.h +resize.o: $(hdrdir)/ruby/internal/attr/cold.h +resize.o: $(hdrdir)/ruby/internal/attr/const.h +resize.o: $(hdrdir)/ruby/internal/attr/constexpr.h +resize.o: $(hdrdir)/ruby/internal/attr/deprecated.h +resize.o: $(hdrdir)/ruby/internal/attr/diagnose_if.h +resize.o: $(hdrdir)/ruby/internal/attr/enum_extensibility.h +resize.o: $(hdrdir)/ruby/internal/attr/error.h +resize.o: $(hdrdir)/ruby/internal/attr/flag_enum.h +resize.o: $(hdrdir)/ruby/internal/attr/forceinline.h +resize.o: $(hdrdir)/ruby/internal/attr/format.h +resize.o: $(hdrdir)/ruby/internal/attr/maybe_unused.h +resize.o: $(hdrdir)/ruby/internal/attr/noalias.h +resize.o: $(hdrdir)/ruby/internal/attr/nodiscard.h +resize.o: $(hdrdir)/ruby/internal/attr/noexcept.h +resize.o: $(hdrdir)/ruby/internal/attr/noinline.h +resize.o: $(hdrdir)/ruby/internal/attr/nonnull.h +resize.o: $(hdrdir)/ruby/internal/attr/noreturn.h +resize.o: $(hdrdir)/ruby/internal/attr/pure.h +resize.o: $(hdrdir)/ruby/internal/attr/restrict.h +resize.o: $(hdrdir)/ruby/internal/attr/returns_nonnull.h +resize.o: $(hdrdir)/ruby/internal/attr/warning.h +resize.o: $(hdrdir)/ruby/internal/attr/weakref.h +resize.o: $(hdrdir)/ruby/internal/cast.h +resize.o: $(hdrdir)/ruby/internal/compiler_is.h +resize.o: $(hdrdir)/ruby/internal/compiler_is/apple.h +resize.o: $(hdrdir)/ruby/internal/compiler_is/clang.h +resize.o: $(hdrdir)/ruby/internal/compiler_is/gcc.h +resize.o: $(hdrdir)/ruby/internal/compiler_is/intel.h +resize.o: $(hdrdir)/ruby/internal/compiler_is/msvc.h +resize.o: $(hdrdir)/ruby/internal/compiler_is/sunpro.h +resize.o: $(hdrdir)/ruby/internal/compiler_since.h +resize.o: $(hdrdir)/ruby/internal/config.h +resize.o: $(hdrdir)/ruby/internal/constant_p.h +resize.o: $(hdrdir)/ruby/internal/core.h +resize.o: $(hdrdir)/ruby/internal/core/rarray.h +resize.o: $(hdrdir)/ruby/internal/core/rbasic.h +resize.o: $(hdrdir)/ruby/internal/core/rbignum.h +resize.o: $(hdrdir)/ruby/internal/core/rclass.h +resize.o: $(hdrdir)/ruby/internal/core/rdata.h +resize.o: $(hdrdir)/ruby/internal/core/rfile.h +resize.o: $(hdrdir)/ruby/internal/core/rhash.h +resize.o: $(hdrdir)/ruby/internal/core/robject.h +resize.o: $(hdrdir)/ruby/internal/core/rregexp.h +resize.o: $(hdrdir)/ruby/internal/core/rstring.h +resize.o: $(hdrdir)/ruby/internal/core/rstruct.h +resize.o: $(hdrdir)/ruby/internal/core/rtypeddata.h +resize.o: $(hdrdir)/ruby/internal/ctype.h +resize.o: $(hdrdir)/ruby/internal/dllexport.h +resize.o: $(hdrdir)/ruby/internal/dosish.h +resize.o: $(hdrdir)/ruby/internal/error.h +resize.o: $(hdrdir)/ruby/internal/eval.h +resize.o: $(hdrdir)/ruby/internal/event.h +resize.o: $(hdrdir)/ruby/internal/fl_type.h +resize.o: $(hdrdir)/ruby/internal/gc.h +resize.o: $(hdrdir)/ruby/internal/glob.h +resize.o: $(hdrdir)/ruby/internal/globals.h +resize.o: $(hdrdir)/ruby/internal/has/attribute.h +resize.o: $(hdrdir)/ruby/internal/has/builtin.h +resize.o: $(hdrdir)/ruby/internal/has/c_attribute.h +resize.o: $(hdrdir)/ruby/internal/has/cpp_attribute.h +resize.o: $(hdrdir)/ruby/internal/has/declspec_attribute.h +resize.o: $(hdrdir)/ruby/internal/has/extension.h +resize.o: $(hdrdir)/ruby/internal/has/feature.h +resize.o: $(hdrdir)/ruby/internal/has/warning.h +resize.o: $(hdrdir)/ruby/internal/intern/array.h +resize.o: $(hdrdir)/ruby/internal/intern/bignum.h +resize.o: $(hdrdir)/ruby/internal/intern/class.h +resize.o: $(hdrdir)/ruby/internal/intern/compar.h +resize.o: $(hdrdir)/ruby/internal/intern/complex.h +resize.o: $(hdrdir)/ruby/internal/intern/cont.h +resize.o: $(hdrdir)/ruby/internal/intern/dir.h +resize.o: $(hdrdir)/ruby/internal/intern/enum.h +resize.o: $(hdrdir)/ruby/internal/intern/enumerator.h +resize.o: $(hdrdir)/ruby/internal/intern/error.h +resize.o: $(hdrdir)/ruby/internal/intern/eval.h +resize.o: $(hdrdir)/ruby/internal/intern/file.h +resize.o: $(hdrdir)/ruby/internal/intern/gc.h +resize.o: $(hdrdir)/ruby/internal/intern/hash.h +resize.o: $(hdrdir)/ruby/internal/intern/io.h +resize.o: $(hdrdir)/ruby/internal/intern/load.h +resize.o: $(hdrdir)/ruby/internal/intern/marshal.h +resize.o: $(hdrdir)/ruby/internal/intern/numeric.h +resize.o: $(hdrdir)/ruby/internal/intern/object.h +resize.o: $(hdrdir)/ruby/internal/intern/parse.h +resize.o: $(hdrdir)/ruby/internal/intern/proc.h +resize.o: $(hdrdir)/ruby/internal/intern/process.h +resize.o: $(hdrdir)/ruby/internal/intern/random.h +resize.o: $(hdrdir)/ruby/internal/intern/range.h +resize.o: $(hdrdir)/ruby/internal/intern/rational.h +resize.o: $(hdrdir)/ruby/internal/intern/re.h +resize.o: $(hdrdir)/ruby/internal/intern/ruby.h +resize.o: $(hdrdir)/ruby/internal/intern/select.h +resize.o: $(hdrdir)/ruby/internal/intern/select/largesize.h +resize.o: $(hdrdir)/ruby/internal/intern/signal.h +resize.o: $(hdrdir)/ruby/internal/intern/sprintf.h +resize.o: $(hdrdir)/ruby/internal/intern/string.h +resize.o: $(hdrdir)/ruby/internal/intern/struct.h +resize.o: $(hdrdir)/ruby/internal/intern/thread.h +resize.o: $(hdrdir)/ruby/internal/intern/time.h +resize.o: $(hdrdir)/ruby/internal/intern/variable.h +resize.o: $(hdrdir)/ruby/internal/intern/vm.h +resize.o: $(hdrdir)/ruby/internal/interpreter.h +resize.o: $(hdrdir)/ruby/internal/iterator.h +resize.o: $(hdrdir)/ruby/internal/memory.h +resize.o: $(hdrdir)/ruby/internal/method.h +resize.o: $(hdrdir)/ruby/internal/module.h +resize.o: $(hdrdir)/ruby/internal/newobj.h +resize.o: $(hdrdir)/ruby/internal/rgengc.h +resize.o: $(hdrdir)/ruby/internal/scan_args.h +resize.o: $(hdrdir)/ruby/internal/special_consts.h +resize.o: $(hdrdir)/ruby/internal/static_assert.h +resize.o: $(hdrdir)/ruby/internal/stdalign.h +resize.o: $(hdrdir)/ruby/internal/stdbool.h +resize.o: $(hdrdir)/ruby/internal/symbol.h +resize.o: $(hdrdir)/ruby/internal/value.h +resize.o: $(hdrdir)/ruby/internal/value_type.h +resize.o: $(hdrdir)/ruby/internal/variable.h +resize.o: $(hdrdir)/ruby/internal/warning_push.h +resize.o: $(hdrdir)/ruby/internal/xmalloc.h +resize.o: $(hdrdir)/ruby/missing.h +resize.o: $(hdrdir)/ruby/ruby.h +resize.o: $(hdrdir)/ruby/st.h +resize.o: $(hdrdir)/ruby/subst.h +resize.o: resize.c +to_ary_conact.o: $(RUBY_EXTCONF_H) +to_ary_conact.o: $(arch_hdrdir)/ruby/config.h +to_ary_conact.o: $(hdrdir)/ruby.h +to_ary_conact.o: $(hdrdir)/ruby/assert.h +to_ary_conact.o: $(hdrdir)/ruby/backward.h +to_ary_conact.o: $(hdrdir)/ruby/backward/2/assume.h +to_ary_conact.o: $(hdrdir)/ruby/backward/2/attributes.h +to_ary_conact.o: $(hdrdir)/ruby/backward/2/bool.h +to_ary_conact.o: $(hdrdir)/ruby/backward/2/gcc_version_since.h +to_ary_conact.o: $(hdrdir)/ruby/backward/2/inttypes.h +to_ary_conact.o: $(hdrdir)/ruby/backward/2/limits.h +to_ary_conact.o: $(hdrdir)/ruby/backward/2/long_long.h +to_ary_conact.o: $(hdrdir)/ruby/backward/2/stdalign.h +to_ary_conact.o: $(hdrdir)/ruby/backward/2/stdarg.h +to_ary_conact.o: $(hdrdir)/ruby/defines.h +to_ary_conact.o: $(hdrdir)/ruby/intern.h +to_ary_conact.o: $(hdrdir)/ruby/internal/anyargs.h +to_ary_conact.o: $(hdrdir)/ruby/internal/arithmetic.h +to_ary_conact.o: $(hdrdir)/ruby/internal/arithmetic/char.h +to_ary_conact.o: $(hdrdir)/ruby/internal/arithmetic/double.h +to_ary_conact.o: $(hdrdir)/ruby/internal/arithmetic/fixnum.h +to_ary_conact.o: $(hdrdir)/ruby/internal/arithmetic/gid_t.h +to_ary_conact.o: $(hdrdir)/ruby/internal/arithmetic/int.h +to_ary_conact.o: $(hdrdir)/ruby/internal/arithmetic/intptr_t.h +to_ary_conact.o: $(hdrdir)/ruby/internal/arithmetic/long.h +to_ary_conact.o: $(hdrdir)/ruby/internal/arithmetic/long_long.h +to_ary_conact.o: $(hdrdir)/ruby/internal/arithmetic/mode_t.h +to_ary_conact.o: $(hdrdir)/ruby/internal/arithmetic/off_t.h +to_ary_conact.o: $(hdrdir)/ruby/internal/arithmetic/pid_t.h +to_ary_conact.o: $(hdrdir)/ruby/internal/arithmetic/short.h +to_ary_conact.o: $(hdrdir)/ruby/internal/arithmetic/size_t.h +to_ary_conact.o: $(hdrdir)/ruby/internal/arithmetic/st_data_t.h +to_ary_conact.o: $(hdrdir)/ruby/internal/arithmetic/uid_t.h +to_ary_conact.o: $(hdrdir)/ruby/internal/assume.h +to_ary_conact.o: $(hdrdir)/ruby/internal/attr/alloc_size.h +to_ary_conact.o: $(hdrdir)/ruby/internal/attr/artificial.h +to_ary_conact.o: $(hdrdir)/ruby/internal/attr/cold.h +to_ary_conact.o: $(hdrdir)/ruby/internal/attr/const.h +to_ary_conact.o: $(hdrdir)/ruby/internal/attr/constexpr.h +to_ary_conact.o: $(hdrdir)/ruby/internal/attr/deprecated.h +to_ary_conact.o: $(hdrdir)/ruby/internal/attr/diagnose_if.h +to_ary_conact.o: $(hdrdir)/ruby/internal/attr/enum_extensibility.h +to_ary_conact.o: $(hdrdir)/ruby/internal/attr/error.h +to_ary_conact.o: $(hdrdir)/ruby/internal/attr/flag_enum.h +to_ary_conact.o: $(hdrdir)/ruby/internal/attr/forceinline.h +to_ary_conact.o: $(hdrdir)/ruby/internal/attr/format.h +to_ary_conact.o: $(hdrdir)/ruby/internal/attr/maybe_unused.h +to_ary_conact.o: $(hdrdir)/ruby/internal/attr/noalias.h +to_ary_conact.o: $(hdrdir)/ruby/internal/attr/nodiscard.h +to_ary_conact.o: $(hdrdir)/ruby/internal/attr/noexcept.h +to_ary_conact.o: $(hdrdir)/ruby/internal/attr/noinline.h +to_ary_conact.o: $(hdrdir)/ruby/internal/attr/nonnull.h +to_ary_conact.o: $(hdrdir)/ruby/internal/attr/noreturn.h +to_ary_conact.o: $(hdrdir)/ruby/internal/attr/pure.h +to_ary_conact.o: $(hdrdir)/ruby/internal/attr/restrict.h +to_ary_conact.o: $(hdrdir)/ruby/internal/attr/returns_nonnull.h +to_ary_conact.o: $(hdrdir)/ruby/internal/attr/warning.h +to_ary_conact.o: $(hdrdir)/ruby/internal/attr/weakref.h +to_ary_conact.o: $(hdrdir)/ruby/internal/cast.h +to_ary_conact.o: $(hdrdir)/ruby/internal/compiler_is.h +to_ary_conact.o: $(hdrdir)/ruby/internal/compiler_is/apple.h +to_ary_conact.o: $(hdrdir)/ruby/internal/compiler_is/clang.h +to_ary_conact.o: $(hdrdir)/ruby/internal/compiler_is/gcc.h +to_ary_conact.o: $(hdrdir)/ruby/internal/compiler_is/intel.h +to_ary_conact.o: $(hdrdir)/ruby/internal/compiler_is/msvc.h +to_ary_conact.o: $(hdrdir)/ruby/internal/compiler_is/sunpro.h +to_ary_conact.o: $(hdrdir)/ruby/internal/compiler_since.h +to_ary_conact.o: $(hdrdir)/ruby/internal/config.h +to_ary_conact.o: $(hdrdir)/ruby/internal/constant_p.h +to_ary_conact.o: $(hdrdir)/ruby/internal/core.h +to_ary_conact.o: $(hdrdir)/ruby/internal/core/rarray.h +to_ary_conact.o: $(hdrdir)/ruby/internal/core/rbasic.h +to_ary_conact.o: $(hdrdir)/ruby/internal/core/rbignum.h +to_ary_conact.o: $(hdrdir)/ruby/internal/core/rclass.h +to_ary_conact.o: $(hdrdir)/ruby/internal/core/rdata.h +to_ary_conact.o: $(hdrdir)/ruby/internal/core/rfile.h +to_ary_conact.o: $(hdrdir)/ruby/internal/core/rhash.h +to_ary_conact.o: $(hdrdir)/ruby/internal/core/robject.h +to_ary_conact.o: $(hdrdir)/ruby/internal/core/rregexp.h +to_ary_conact.o: $(hdrdir)/ruby/internal/core/rstring.h +to_ary_conact.o: $(hdrdir)/ruby/internal/core/rstruct.h +to_ary_conact.o: $(hdrdir)/ruby/internal/core/rtypeddata.h +to_ary_conact.o: $(hdrdir)/ruby/internal/ctype.h +to_ary_conact.o: $(hdrdir)/ruby/internal/dllexport.h +to_ary_conact.o: $(hdrdir)/ruby/internal/dosish.h +to_ary_conact.o: $(hdrdir)/ruby/internal/error.h +to_ary_conact.o: $(hdrdir)/ruby/internal/eval.h +to_ary_conact.o: $(hdrdir)/ruby/internal/event.h +to_ary_conact.o: $(hdrdir)/ruby/internal/fl_type.h +to_ary_conact.o: $(hdrdir)/ruby/internal/gc.h +to_ary_conact.o: $(hdrdir)/ruby/internal/glob.h +to_ary_conact.o: $(hdrdir)/ruby/internal/globals.h +to_ary_conact.o: $(hdrdir)/ruby/internal/has/attribute.h +to_ary_conact.o: $(hdrdir)/ruby/internal/has/builtin.h +to_ary_conact.o: $(hdrdir)/ruby/internal/has/c_attribute.h +to_ary_conact.o: $(hdrdir)/ruby/internal/has/cpp_attribute.h +to_ary_conact.o: $(hdrdir)/ruby/internal/has/declspec_attribute.h +to_ary_conact.o: $(hdrdir)/ruby/internal/has/extension.h +to_ary_conact.o: $(hdrdir)/ruby/internal/has/feature.h +to_ary_conact.o: $(hdrdir)/ruby/internal/has/warning.h +to_ary_conact.o: $(hdrdir)/ruby/internal/intern/array.h +to_ary_conact.o: $(hdrdir)/ruby/internal/intern/bignum.h +to_ary_conact.o: $(hdrdir)/ruby/internal/intern/class.h +to_ary_conact.o: $(hdrdir)/ruby/internal/intern/compar.h +to_ary_conact.o: $(hdrdir)/ruby/internal/intern/complex.h +to_ary_conact.o: $(hdrdir)/ruby/internal/intern/cont.h +to_ary_conact.o: $(hdrdir)/ruby/internal/intern/dir.h +to_ary_conact.o: $(hdrdir)/ruby/internal/intern/enum.h +to_ary_conact.o: $(hdrdir)/ruby/internal/intern/enumerator.h +to_ary_conact.o: $(hdrdir)/ruby/internal/intern/error.h +to_ary_conact.o: $(hdrdir)/ruby/internal/intern/eval.h +to_ary_conact.o: $(hdrdir)/ruby/internal/intern/file.h +to_ary_conact.o: $(hdrdir)/ruby/internal/intern/gc.h +to_ary_conact.o: $(hdrdir)/ruby/internal/intern/hash.h +to_ary_conact.o: $(hdrdir)/ruby/internal/intern/io.h +to_ary_conact.o: $(hdrdir)/ruby/internal/intern/load.h +to_ary_conact.o: $(hdrdir)/ruby/internal/intern/marshal.h +to_ary_conact.o: $(hdrdir)/ruby/internal/intern/numeric.h +to_ary_conact.o: $(hdrdir)/ruby/internal/intern/object.h +to_ary_conact.o: $(hdrdir)/ruby/internal/intern/parse.h +to_ary_conact.o: $(hdrdir)/ruby/internal/intern/proc.h +to_ary_conact.o: $(hdrdir)/ruby/internal/intern/process.h +to_ary_conact.o: $(hdrdir)/ruby/internal/intern/random.h +to_ary_conact.o: $(hdrdir)/ruby/internal/intern/range.h +to_ary_conact.o: $(hdrdir)/ruby/internal/intern/rational.h +to_ary_conact.o: $(hdrdir)/ruby/internal/intern/re.h +to_ary_conact.o: $(hdrdir)/ruby/internal/intern/ruby.h +to_ary_conact.o: $(hdrdir)/ruby/internal/intern/select.h +to_ary_conact.o: $(hdrdir)/ruby/internal/intern/select/largesize.h +to_ary_conact.o: $(hdrdir)/ruby/internal/intern/signal.h +to_ary_conact.o: $(hdrdir)/ruby/internal/intern/sprintf.h +to_ary_conact.o: $(hdrdir)/ruby/internal/intern/string.h +to_ary_conact.o: $(hdrdir)/ruby/internal/intern/struct.h +to_ary_conact.o: $(hdrdir)/ruby/internal/intern/thread.h +to_ary_conact.o: $(hdrdir)/ruby/internal/intern/time.h +to_ary_conact.o: $(hdrdir)/ruby/internal/intern/variable.h +to_ary_conact.o: $(hdrdir)/ruby/internal/intern/vm.h +to_ary_conact.o: $(hdrdir)/ruby/internal/interpreter.h +to_ary_conact.o: $(hdrdir)/ruby/internal/iterator.h +to_ary_conact.o: $(hdrdir)/ruby/internal/memory.h +to_ary_conact.o: $(hdrdir)/ruby/internal/method.h +to_ary_conact.o: $(hdrdir)/ruby/internal/module.h +to_ary_conact.o: $(hdrdir)/ruby/internal/newobj.h +to_ary_conact.o: $(hdrdir)/ruby/internal/rgengc.h +to_ary_conact.o: $(hdrdir)/ruby/internal/scan_args.h +to_ary_conact.o: $(hdrdir)/ruby/internal/special_consts.h +to_ary_conact.o: $(hdrdir)/ruby/internal/static_assert.h +to_ary_conact.o: $(hdrdir)/ruby/internal/stdalign.h +to_ary_conact.o: $(hdrdir)/ruby/internal/stdbool.h +to_ary_conact.o: $(hdrdir)/ruby/internal/symbol.h +to_ary_conact.o: $(hdrdir)/ruby/internal/value.h +to_ary_conact.o: $(hdrdir)/ruby/internal/value_type.h +to_ary_conact.o: $(hdrdir)/ruby/internal/variable.h +to_ary_conact.o: $(hdrdir)/ruby/internal/warning_push.h +to_ary_conact.o: $(hdrdir)/ruby/internal/xmalloc.h +to_ary_conact.o: $(hdrdir)/ruby/missing.h +to_ary_conact.o: $(hdrdir)/ruby/ruby.h +to_ary_conact.o: $(hdrdir)/ruby/st.h +to_ary_conact.o: $(hdrdir)/ruby/subst.h +to_ary_conact.o: to_ary_conact.c +# AUTOGENERATED DEPENDENCIES END diff --git a/ext/-test-/array/concat/extconf.rb b/ext/-test-/array/concat/extconf.rb new file mode 100644 index 0000000000..cdd79126c9 --- /dev/null +++ b/ext/-test-/array/concat/extconf.rb @@ -0,0 +1,2 @@ +# frozen_string_literal: false +create_makefile("-test-/array/to_ary_concat") diff --git a/ext/-test-/array/concat/to_ary_conact.c b/ext/-test-/array/concat/to_ary_conact.c new file mode 100644 index 0000000000..a61659a66e --- /dev/null +++ b/ext/-test-/array/concat/to_ary_conact.c @@ -0,0 +1,64 @@ +#include "ruby.h" + +VALUE cFoo; + +// Foo + +typedef struct { + int dummy; +} Foo; + +static void Foo_free(void* _self) { + xfree(_self); +} + +static rb_data_type_t Foo_type = { + "Foo", + {NULL, Foo_free, NULL }, + .flags = RUBY_TYPED_FREE_IMMEDIATELY, +}; + +static VALUE Foo_alloc(VALUE klass) { + Foo* _self = ALLOC(Foo); + return TypedData_Wrap_Struct(klass, &Foo_type, _self); +} + +// Bar + +typedef struct { + int dummy; +} Bar; + +static void Bar_free(void* _self) { + xfree(_self); +} + +static rb_data_type_t Bar_type = { + "Bar", + {NULL, Bar_free, NULL }, + .flags = RUBY_TYPED_FREE_IMMEDIATELY, +}; + +static VALUE Bar_alloc(VALUE klass) { + Bar* bar = ALLOC(Bar); + return TypedData_Wrap_Struct(klass, &Bar_type, bar); +} + +VALUE Bar_to_ary(VALUE _self) { + VALUE ary = rb_ary_new2(2); + rb_ary_push(ary, Foo_alloc(cFoo)); + rb_ary_push(ary, Foo_alloc(cFoo)); + rb_ary_push(ary, Foo_alloc(cFoo)); + return ary; +} + +void Init_to_ary_concat() { + VALUE mBug = rb_define_module("Bug"); + cFoo = rb_define_class_under(mBug, "Foo", rb_cObject); + rb_gc_register_address(&cFoo); + rb_define_alloc_func(cFoo, Foo_alloc); + + VALUE bar = rb_define_class_under(mBug, "Bar", rb_cObject); + rb_define_alloc_func(bar, Bar_alloc); + rb_define_method(bar, "to_ary", Bar_to_ary, 0); +} diff --git a/test/-ext-/array/test_to_ary_concat.rb b/test/-ext-/array/test_to_ary_concat.rb new file mode 100644 index 0000000000..feb1bc1109 --- /dev/null +++ b/test/-ext-/array/test_to_ary_concat.rb @@ -0,0 +1,20 @@ +# frozen_string_literal: false +require 'test/unit' +require '-test-/array/to_ary_concat' + +class TestConcatStress < Test::Unit::TestCase + def setup + @stress_level = GC.stress + GC.stress = true + end + + def teardown + GC.stress = @stress_level + end + + def test_concat + arr = [nil] + bar = Bug::Bar.new + arr.concat(bar) + end +end