From f676484ee6e96cc4a5f930d39a99cbcaa11e95fb Mon Sep 17 00:00:00 2001 From: nobu Date: Sat, 16 Apr 2016 01:00:13 +0000 Subject: struct.c: unique members * struct.c (struct_make_members_list, rb_struct_s_def): member names should be unique. [ruby-core:74971] [Bug #12291] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@54612 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- struct.c | 27 ++++++++++++++++++++------- 1 file changed, 20 insertions(+), 7 deletions(-) (limited to 'struct.c') diff --git a/struct.c b/struct.c index ee63f4e148..a4cab45945 100644 --- a/struct.c +++ b/struct.c @@ -334,12 +334,19 @@ static VALUE struct_make_members_list(va_list ar) { char *mem; - VALUE ary = rb_ary_tmp_new(0); + VALUE ary, list = rb_ident_hash_new(); + st_table *tbl = RHASH_TBL(list); + RBASIC_CLEAR_CLASS(list); while ((mem = va_arg(ar, char*)) != 0) { VALUE sym = rb_sym_intern_ascii_cstr(mem); - rb_ary_push(ary, sym); + if (st_insert(tbl, sym, Qtrue)) { + rb_raise(rb_eArgError, "duplicate member: %s", mem); + } } + ary = rb_hash_keys(list); + st_clear(tbl); + RBASIC_CLEAR_CLASS(ary); OBJ_FREEZE_RAW(ary); return ary; } @@ -482,7 +489,7 @@ rb_struct_s_def(int argc, VALUE *argv, VALUE klass) VALUE name, rest; long i; VALUE st; - ID id; + st_table *tbl; rb_check_arity(argc, 1, UNLIMITED_ARGUMENTS); name = argv[0]; @@ -493,12 +500,18 @@ rb_struct_s_def(int argc, VALUE *argv, VALUE klass) --argc; ++argv; } - rest = rb_ary_tmp_new(argc); + rest = rb_ident_hash_new(); + RBASIC_CLEAR_CLASS(rest); + tbl = RHASH_TBL(rest); for (i=0; i