diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2020-04-21 13:14:10 +0900 |
|---|---|---|
| committer | Yukihiro "Matz" Matsumoto <[email protected]> | 2020-04-21 13:21:12 +0900 |
| commit | c181d89c9dca0e722a525b871a82cbd75c59bb80 (patch) | |
| tree | 564331a8ac7af70ede3ad009543b85e6d00ebdce /src | |
| parent | c91c9e2429b31fb2f35ed297152100084531b0cb (diff) | |
| download | mruby-c181d89c9dca0e722a525b871a82cbd75c59bb80.tar.gz mruby-c181d89c9dca0e722a525b871a82cbd75c59bb80.zip | |
`Kernel#clone` and `Kernel#dup` no longer raise `TypeError`; fix #4974
In ISO, those methods should raise `TypeError`, but the spec has been
changed. The change was discussed in [Feature#12979].
Diffstat (limited to 'src')
| -rw-r--r-- | src/kernel.c | 4 |
1 files changed, 2 insertions, 2 deletions
diff --git a/src/kernel.c b/src/kernel.c index 8bb837eca..ae9617686 100644 --- a/src/kernel.c +++ b/src/kernel.c @@ -325,7 +325,7 @@ mrb_obj_clone(mrb_state *mrb, mrb_value self) mrb_value clone; if (mrb_immediate_p(self)) { - mrb_raisef(mrb, E_TYPE_ERROR, "can't clone %v", self); + return self; } if (mrb_sclass_p(self)) { mrb_raise(mrb, E_TYPE_ERROR, "can't clone singleton class"); @@ -366,7 +366,7 @@ mrb_obj_dup(mrb_state *mrb, mrb_value obj) mrb_value dup; if (mrb_immediate_p(obj)) { - mrb_raisef(mrb, E_TYPE_ERROR, "can't dup %v", obj); + return obj; } if (mrb_sclass_p(obj)) { mrb_raise(mrb, E_TYPE_ERROR, "can't dup singleton class"); |
