summaryrefslogtreecommitdiff
path: root/gc.c
diff options
context:
space:
mode:
authorKoichi Sasada <ko1@atdot.net>2019-07-15 10:39:28 +0900
committerKoichi Sasada <ko1@atdot.net>2019-07-15 10:39:57 +0900
commitf326b4f4af4963e252d24c4f7d7099fc607db859 (patch)
treeb568423cf1147687c2343a083071801b683cbcd7 /gc.c
parentdd4f128ac5fa26e3d8c4d003c770e69f9ed9a91e (diff)
simplify around GC_ASSERT()
Diffstat (limited to 'gc.c')
-rw-r--r--gc.c15
1 files changed, 6 insertions, 9 deletions
diff --git a/gc.c b/gc.c
index a5e11f8032..f1e9ecf47c 100644
--- a/gc.c
+++ b/gc.c
@@ -236,11 +236,8 @@ int ruby_rgengc_debug;
#define RGENGC_CHECK_MODE 0
#endif
-#if RGENGC_CHECK_MODE > 0
+// Note: using RUBY_ASSERT_WHEN() extend a macro in expr (info by nobu).
#define GC_ASSERT(expr) RUBY_ASSERT_MESG_WHEN(RGENGC_CHECK_MODE > 0, expr, #expr)
-#else
-#define GC_ASSERT(expr) ((void)0)
-#endif
/* RGENGC_OLD_NEWOBJ_CHECK
* 0: disable all assertions
@@ -1946,8 +1943,8 @@ static inline VALUE
newobj_init(VALUE klass, VALUE flags, VALUE v1, VALUE v2, VALUE v3, int wb_protected, rb_objspace_t *objspace, VALUE obj)
{
#if !__has_feature(memory_sanitizer)
- assert(BUILTIN_TYPE(obj) == T_NONE);
- assert((flags & FL_WB_PROTECTED) == 0);
+ GC_ASSERT(BUILTIN_TYPE(obj) == T_NONE);
+ GC_ASSERT((flags & FL_WB_PROTECTED) == 0);
#endif
/* OBJSETUP */
@@ -2339,7 +2336,7 @@ obj_free(rb_objspace_t *objspace, VALUE obj)
FL_UNSET(obj, FL_SEEN_OBJ_ID);
if (st_delete(objspace->obj_to_id_tbl, (st_data_t *)&obj, &id)) {
- assert(id);
+ GC_ASSERT(id);
st_delete(objspace->id_to_obj_tbl, (st_data_t *)&id, NULL);
}
else {
@@ -3439,11 +3436,11 @@ cached_object_id(VALUE obj)
rb_objspace_t *objspace = &rb_objspace;
if (st_lookup(objspace->obj_to_id_tbl, (st_data_t)obj, &id)) {
- assert(FL_TEST(obj, FL_SEEN_OBJ_ID));
+ GC_ASSERT(FL_TEST(obj, FL_SEEN_OBJ_ID));
return nonspecial_obj_id(id);
}
else {
- assert(!FL_TEST(obj, FL_SEEN_OBJ_ID));
+ GC_ASSERT(!FL_TEST(obj, FL_SEEN_OBJ_ID));
id = obj;
while (1) {