diff options
| author | Yukihiro "Matz" Matsumoto <[email protected]> | 2017-12-12 18:41:18 +0900 |
|---|---|---|
| committer | Yukihiro "Matz" Matsumoto <[email protected]> | 2017-12-12 18:41:18 +0900 |
| commit | bbb088234395efda23540d30ab5d1cb40f220d82 (patch) | |
| tree | 4f66588878264c0d2a17529629d7d183d6a49d29 /src | |
| parent | d4ff92bcf65ce140495014f40d22b93a1b1fb957 (diff) | |
| download | mruby-bbb088234395efda23540d30ab5d1cb40f220d82.tar.gz mruby-bbb088234395efda23540d30ab5d1cb40f220d82.zip | |
Modifying frozen objects will raise `FrozenError`.
`FrozenError` is a subclass of `RuntimeError` which used to be
raised. [Ruby2.5]
Diffstat (limited to 'src')
| -rw-r--r-- | src/array.c | 2 | ||||
| -rw-r--r-- | src/class.c | 4 | ||||
| -rw-r--r-- | src/hash.c | 2 | ||||
| -rw-r--r-- | src/string.c | 2 | ||||
| -rw-r--r-- | src/variable.c | 2 |
5 files changed, 6 insertions, 6 deletions
diff --git a/src/array.c b/src/array.c index 47a582ffc..285e48a0f 100644 --- a/src/array.c +++ b/src/array.c @@ -114,7 +114,7 @@ static void ary_modify_check(mrb_state *mrb, struct RArray *a) { if (MRB_FROZEN_P(a)) { - mrb_raise(mrb, E_RUNTIME_ERROR, "can't modify frozen array"); + mrb_raise(mrb, E_FROZEN_ERROR, "can't modify frozen array"); } } diff --git a/src/class.c b/src/class.c index 986af5531..9cb2a9a3a 100644 --- a/src/class.c +++ b/src/class.c @@ -430,9 +430,9 @@ mrb_define_method_raw(mrb_state *mrb, struct RClass *c, mrb_sym mid, mrb_method_ if (MRB_FROZEN_P(c)) { if (c->tt == MRB_TT_MODULE) - mrb_raise(mrb, E_RUNTIME_ERROR, "can't modify frozen module"); + mrb_raise(mrb, E_FROZEN_ERROR, "can't modify frozen module"); else - mrb_raise(mrb, E_RUNTIME_ERROR, "can't modify frozen class"); + mrb_raise(mrb, E_FROZEN_ERROR, "can't modify frozen class"); } if (!h) h = c->mt = kh_init(mt, mrb); k = kh_put(mt, mrb, h, mid); diff --git a/src/hash.c b/src/hash.c index feb06d843..d58706954 100644 --- a/src/hash.c +++ b/src/hash.c @@ -286,7 +286,7 @@ static void mrb_hash_modify(mrb_state *mrb, mrb_value hash) { if (MRB_FROZEN_P(mrb_hash_ptr(hash))) { - mrb_raise(mrb, E_RUNTIME_ERROR, "can't modify frozen hash"); + mrb_raise(mrb, E_FROZEN_ERROR, "can't modify frozen hash"); } mrb_hash_tbl(mrb, hash); } diff --git a/src/string.c b/src/string.c index da475839c..d4dc517cf 100644 --- a/src/string.c +++ b/src/string.c @@ -494,7 +494,7 @@ static void check_frozen(mrb_state *mrb, struct RString *s) { if (MRB_FROZEN_P(s)) { - mrb_raise(mrb, E_RUNTIME_ERROR, "can't modify frozen string"); + mrb_raise(mrb, E_FROZEN_ERROR, "can't modify frozen string"); } } diff --git a/src/variable.c b/src/variable.c index f0bfa19cc..968fc2fc1 100644 --- a/src/variable.c +++ b/src/variable.c @@ -261,7 +261,7 @@ mrb_obj_iv_set(mrb_state *mrb, struct RObject *obj, mrb_sym sym, mrb_value v) iv_tbl *t = obj->iv; if (MRB_FROZEN_P(obj)) { - mrb_raisef(mrb, E_RUNTIME_ERROR, "can't modify frozen %S", mrb_obj_value(obj)); + mrb_raisef(mrb, E_FROZEN_ERROR, "can't modify frozen %S", mrb_obj_value(obj)); } if (!t) { t = obj->iv = iv_new(mrb); |
