diff options
| author | yugui <yugui@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2009-05-22 09:49:35 +0000 |
|---|---|---|
| committer | yugui <yugui@b2dd03c8-39d4-4d8f-98ff-823fe69b080e> | 2009-05-22 09:49:35 +0000 |
| commit | a922df795b333a56bedfb0428348ed35f31720ca (patch) | |
| tree | 2b290a9ebf499c8976f629e78fc811747ad1851a | |
| parent | 68a2b3cf7f4ba888501b760c26b6855bb9ad0092 (diff) | |
merges r23491 from trunk into ruby_1_9_1.
--
* vm_method.c (rb_attr): should preserve encoding info.
[ruby-dev:38498]
git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_1_9_1@23536 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
| -rw-r--r-- | ChangeLog | 5 | ||||
| -rw-r--r-- | version.h | 2 | ||||
| -rw-r--r-- | vm_method.c | 5 |
3 files changed, 10 insertions, 2 deletions
@@ -1,3 +1,8 @@ +Wed May 20 00:05:52 2009 Yukihiro Matsumoto <matz@ruby-lang.org> + + * vm_method.c (rb_attr): should preserve encoding info. + [ruby-dev:38498] + Sun May 17 14:23:08 2009 Nobuyoshi Nakada <nobu@ruby-lang.org> * compile.c (rb_parse_in_eval): returns true in true eval, not in @@ -1,6 +1,6 @@ #define RUBY_VERSION "1.9.1" #define RUBY_RELEASE_DATE "2009-05-12" -#define RUBY_PATCHLEVEL 150 +#define RUBY_PATCHLEVEL 151 #define RUBY_VERSION_MAJOR 1 #define RUBY_VERSION_MINOR 9 #define RUBY_VERSION_TEENY 1 diff --git a/vm_method.c b/vm_method.c index 774fa1eda9..19a8a3ebbb 100644 --- a/vm_method.c +++ b/vm_method.c @@ -432,6 +432,7 @@ rb_attr(VALUE klass, ID id, int read, int write, int ex) { const char *name; ID attriv; + VALUE aname; int noex; if (!ex) { @@ -459,7 +460,9 @@ rb_attr(VALUE klass, ID id, int read, int write, int ex) if (!name) { rb_raise(rb_eArgError, "argument needs to be symbol or string"); } - attriv = rb_intern_str(rb_sprintf("@%s", name)); + aname = rb_sprintf("@%s", name); + rb_enc_copy(aname, rb_id2str(id)); + attriv = rb_intern_str(aname); if (read) { rb_add_method(klass, id, NEW_IVAR(attriv), noex); } |
