path: root/class.c
diff options
authorYusuke Endoh <>2019-09-22 16:21:26 +0900
committerYusuke Endoh <>2019-09-22 16:21:26 +0900
commit28eefb33c8d27e5711319873d065e5414d7ffe25 (patch)
tree613cd991350e759ef6ecf6052ee5520a76833c51 /class.c
parentb4c328bebcf45b7a983f7e5ce29ba6ec57ed1a1a (diff)
variable.c: Rename rb_st_copy to rb_iv_tbl_copy
This function was created as a variant of st_copy with firing write barrier. It should have more explicit name, such as st_copy_with_write_barrier. But because it is used only for copying iv_tbl, so I rename it to rb_iv_tbl_copy now. If we face other use case than iv_tbl, we may want to rename it to more general name.
Diffstat (limited to 'class.c')
1 files changed, 2 insertions, 2 deletions
diff --git a/class.c b/class.c
index 6b3b662..08e0539 100644
--- a/class.c
+++ b/class.c
@@ -341,7 +341,7 @@ rb_mod_init_copy(VALUE clone, VALUE orig)
if (RCLASS_IV_TBL(orig)) {
st_data_t id;
- RCLASS_IV_TBL(clone) = rb_st_copy(clone, RCLASS_IV_TBL(orig));
+ rb_iv_tbl_copy(clone, orig);
CONST_ID(id, "__tmp_classpath__");
st_delete(RCLASS_IV_TBL(clone), &id, 0);
CONST_ID(id, "__classpath__");
@@ -394,7 +394,7 @@ rb_singleton_class_clone_and_attach(VALUE obj, VALUE attach)
RCLASS_EXT(clone)->allocator = RCLASS_EXT(klass)->allocator;
if (RCLASS_IV_TBL(klass)) {
- RCLASS_IV_TBL(clone) = rb_st_copy(clone, RCLASS_IV_TBL(klass));
+ rb_iv_tbl_copy(clone, klass);
if (RCLASS_CONST_TBL(klass)) {
struct clone_const_arg arg;