ruby-changes:2003
From: ko1@a...
Date: 23 Sep 2007 08:58:15 +0900
Subject: [ruby-changes:2003] nobu - Ruby:r13494 (ruby_1_8, trunk): * eval_method.ci (rb_attr): should not use alloca for unknowen size
nobu 2007-09-23 08:58:03 +0900 (Sun, 23 Sep 2007) New Revision: 13494 Modified files: branches/ruby_1_8/ChangeLog trunk/ChangeLog trunk/eval_method.ci trunk/parse.y Log: * eval_method.ci (rb_attr): should not use alloca for unknowen size input. [ruby-dev:31816] * parse.y (rb_intern_str): prevent str from optimization. http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/branches/ruby_1_8/ChangeLog?r1=13494&r2=13493 http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/parse.y?r1=13494&r2=13493 http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/ChangeLog?r1=13494&r2=13493 http://svn.ruby-lang.org/cgi-bin/viewvc.cgi/trunk/eval_method.ci?r1=13494&r2=13493 Index: eval_method.ci =================================================================== --- eval_method.ci (revision 13493) +++ eval_method.ci (revision 13494) @@ -409,10 +409,8 @@ rb_attr(VALUE klass, ID id, int read, int write, int ex) { const char *name; - char *buf; ID attriv; int noex; - size_t len; if (!ex) { noex = NOEX_PUBLIC; @@ -439,10 +437,7 @@ if (!name) { rb_raise(rb_eArgError, "argument needs to be symbol or string"); } - len = strlen(name) + 2; - buf = ALLOCA_N(char, len); - snprintf(buf, len, "@%s", name); - attriv = rb_intern(buf); + attriv = rb_intern_str(rb_sprintf("@%s", name)); if (read) { rb_add_method(klass, id, NEW_IVAR(attriv), noex); } Index: ChangeLog =================================================================== --- ChangeLog (revision 13493) +++ ChangeLog (revision 13494) @@ -1,3 +1,10 @@ +Sun Sep 23 08:58:01 2007 Nobuyoshi Nakada <nobu@r...> + + * eval_method.ci (rb_attr): should not use alloca for unknowen size + input. [ruby-dev:31816] + + * parse.y (rb_intern_str): prevent str from optimization. + Sun Sep 23 06:16:04 2007 Nobuyoshi Nakada <nobu@r...> * eval_method.ci (remove_method): check for undefined method. Index: parse.y =================================================================== --- parse.y (revision 13493) +++ parse.y (revision 13494) @@ -8528,7 +8528,9 @@ ID rb_intern_str(VALUE str) { - return rb_intern3(RSTRING_PTR(str), RSTRING_LEN(str), rb_enc_get(str)); + ID id = rb_intern3(RSTRING_PTR(str), RSTRING_LEN(str), rb_enc_get(str)); + RB_GC_GUARD(str); + return id; } VALUE Index: ruby_1_8/ChangeLog =================================================================== --- ruby_1_8/ChangeLog (revision 13493) +++ ruby_1_8/ChangeLog (revision 13494) @@ -1,3 +1,10 @@ +Sun Sep 23 08:58:01 2007 Nobuyoshi Nakada <nobu@r...> + + * eval_method.ci (rb_attr): should not use alloca for unknowen size + input. [ruby-dev:31816] + + * parse.y (rb_intern_str): prevent str from optimization. + Sun Sep 23 05:42:35 2007 URABE Shyouhei <shyouhei@r...> * lib/rdoc/options.rb (Options::check_diagram): dot -V output -- ML: ruby-changes@q... Info: http://www.atdot.net/~ko1/quickml