summaryrefslogtreecommitdiffhomepage
diff options
context:
space:
mode:
authortake_cheeze <[email protected]>2014-04-01 01:53:28 +0900
committertake_cheeze <[email protected]>2014-04-01 01:53:28 +0900
commit755ded2ef087bc29c8223919a3e8ab95a0692de4 (patch)
treea165a984dea67e3c0bf752707c7e89e1052f7a3c
parentb38eb72d829edc94c6a9f5d34bb6e5c102039cb5 (diff)
downloadmruby-755ded2ef087bc29c8223919a3e8ab95a0692de4.tar.gz
mruby-755ded2ef087bc29c8223919a3e8ab95a0692de4.zip
Use MRB_ENV_STACK_SHARED_P to check `cioff` field of REnv.
-rw-r--r--include/mruby/proc.h1
-rw-r--r--src/gc.c4
-rw-r--r--src/vm.c8
3 files changed, 7 insertions, 6 deletions
diff --git a/include/mruby/proc.h b/include/mruby/proc.h
index e72e8f7e4..870e9f748 100644
--- a/include/mruby/proc.h
+++ b/include/mruby/proc.h
@@ -22,6 +22,7 @@ struct REnv {
#define MRB_ENV_STACK_LEN(e) ((e)->flags)
#define MRB_ENV_UNSHARE_STACK(e) ((e)->cioff = -1)
+#define MRB_ENV_STACK_SHARED_P(e) ((e)->cioff >= 0)
struct RProc {
MRB_OBJECT_HEADER;
diff --git a/src/gc.c b/src/gc.c
index 426a84514..4db640ff4 100644
--- a/src/gc.c
+++ b/src/gc.c
@@ -515,7 +515,7 @@ gc_mark_children(mrb_state *mrb, struct RBasic *obj)
{
struct REnv *e = (struct REnv*)obj;
- if (e->cioff < 0) {
+ if (!MRB_ENV_STACK_SHARED_P(e)) {
int i, len;
len = (int)MRB_ENV_STACK_LEN(e);
@@ -612,7 +612,7 @@ obj_free(mrb_state *mrb, struct RBasic *obj)
{
struct REnv *e = (struct REnv*)obj;
- if (e->cioff < 0) {
+ if (!MRB_ENV_STACK_SHARED_P(e)) {
mrb_free(mrb, e->stack);
e->stack = NULL;
}
diff --git a/src/vm.c b/src/vm.c
index 4aa9b9460..09988a996 100644
--- a/src/vm.c
+++ b/src/vm.c
@@ -121,7 +121,7 @@ envadjust(mrb_state *mrb, mrb_value *oldbase, mrb_value *newbase)
if (newbase == oldbase) return;
while (ci <= mrb->c->ci) {
struct REnv *e = ci->env;
- if (e && e->cioff >= 0) {
+ if (e && MRB_ENV_STACK_SHARED_P(e)) {
ptrdiff_t off = e->stack - oldbase;
e->stack = newbase + off;
@@ -188,7 +188,7 @@ is_strict(mrb_state *mrb, struct REnv *e)
{
int cioff = e->cioff;
- if (cioff >= 0 && mrb->c->cibase[cioff].proc &&
+ if (MRB_ENV_STACK_SHARED_P(e) && mrb->c->cibase[cioff].proc &&
MRB_PROC_STRICT_P(mrb->c->cibase[cioff].proc)) {
return TRUE;
}
@@ -1406,7 +1406,7 @@ RETRY_TRY_BLOCK:
if (proc->env && !MRB_PROC_STRICT_P(proc)) {
struct REnv *e = top_env(mrb, proc);
- if (e->cioff < 0) {
+ if (!MRB_ENV_STACK_SHARED_P(e)) {
localjump_error(mrb, LOCALJUMP_ERROR_RETURN);
goto L_RAISE;
}
@@ -1437,7 +1437,7 @@ RETRY_TRY_BLOCK:
ci = mrb->c->ci;
break;
case OP_R_BREAK:
- if (!proc->env || proc->env->cioff < 0) {
+ if (!proc->env || !MRB_ENV_STACK_SHARED_P(proc->env)) {
localjump_error(mrb, LOCALJUMP_ERROR_BREAK);
goto L_RAISE;
}