diff options
| author | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2005-02-09 15:55:36 +0000 |
|---|---|---|
| committer | matz <matz@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2005-02-09 15:55:36 +0000 |
| commit | 939499ffad8053c31302f2d1db5fd274ae3cb1a4 (patch) | |
| tree | 482bcfb90df8c4b1f0f1539622b60b20a123450a /struct.c | |
| parent | 4862e92d4a184ad0ddfbfdd05b3174b904032ed7 (diff) | |
| download | ruby-939499ffad8053c31302f2d1db5fd274ae3cb1a4.tar.gz ruby-939499ffad8053c31302f2d1db5fd274ae3cb1a4.tar.xz ruby-939499ffad8053c31302f2d1db5fd274ae3cb1a4.zip | |
* struct.c (make_struct): fixed: [ruby-core:04402]
git-svn-id: http://svn.ruby-lang.org/repos/ruby/branches/ruby_1_8@7933 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
Diffstat (limited to 'struct.c')
| -rw-r--r-- | struct.c | 4 |
1 files changed, 4 insertions, 0 deletions
@@ -212,6 +212,10 @@ make_struct(name, members, klass) rb_define_singleton_method(nstr, "members", rb_struct_s_members_m, 0); for (i=0; i< RARRAY(members)->len; i++) { ID id = SYM2ID(RARRAY(members)->ptr[i]); + if (!rb_is_local_id(id)) { + rb_raise(rb_eNameError, "`%s' is not proper name for a struct member", + rb_id2name(id)); + } if (i<10) { rb_define_method_id(nstr, id, ref_func[i], 0); } |
