From e36c3c1ddb7678b7641f936961412110b8d3d5be Mon Sep 17 00:00:00 2001 From: shyouhei Date: Sun, 15 Jun 2008 13:44:09 +0000 Subject: merge revision(s) 16307: * struct.c (rb_struct_s_def): to_str should be called only once. [ruby-core:16647] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_8_5@17276 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- struct.c | 13 ++++--------- 1 file changed, 4 insertions(+), 9 deletions(-) (limited to 'struct.c') diff --git a/struct.c b/struct.c index 0dd5aba0a0..0e2b26f8fc 100644 --- a/struct.c +++ b/struct.c @@ -307,19 +307,14 @@ rb_struct_s_def(argc, argv, klass) ID id; rb_scan_args(argc, argv, "1*", &name, &rest); + if (!NIL_P(name) && SYMBOL_P(name)) { + rb_ary_unshift(rest, name); + name = Qnil; + } for (i=0; ilen; i++) { id = rb_to_id(RARRAY(rest)->ptr[i]); RARRAY(rest)->ptr[i] = ID2SYM(id); } - if (!NIL_P(name)) { - VALUE tmp = rb_check_string_type(name); - - if (NIL_P(tmp)) { - id = rb_to_id(name); - rb_ary_unshift(rest, ID2SYM(id)); - name = Qnil; - } - } st = make_struct(name, rest, klass); if (rb_block_given_p()) { rb_mod_module_eval(0, 0, st); -- cgit v1.2.3