minor changes only
This commit is contained in:
parent
12298f5ed1
commit
821b68a971
@ -1747,7 +1747,7 @@ static MOO_INLINE int activate_new_method (moo_t* moo, moo_oop_method_t mth, moo
|
||||
}
|
||||
}
|
||||
/* copy receiver */
|
||||
MOO_STORE_OOP (moo, &ctx->receiver_or_source, MOO_STACK_GETTOP(moo));
|
||||
MOO_STORE_OOP (moo, &ctx->receiver_or_base, MOO_STACK_GETTOP(moo));
|
||||
MOO_STACK_POP (moo);
|
||||
|
||||
MOO_ASSERT (moo, moo->sp >= -1);
|
||||
@ -2067,6 +2067,7 @@ TODO: overcome this problem - accept parameters....
|
||||
|
||||
ctx->ip = MOO_SMOOI_TO_OOP(0); /* point to the beginning */
|
||||
ctx->sp = MOO_SMOOI_TO_OOP(-1); /* pointer to -1 below the bottom */
|
||||
/* ctx->home = moo->_nil; */
|
||||
MOO_STORE_OOP (moo, (moo_oop_t*)&ctx->origin, (moo_oop_t)ctx); /* point to self */
|
||||
MOO_STORE_OOP (moo, (moo_oop_t*)&ctx->method_or_nargs, (moo_oop_t)mth); /* fake. help SWITCH_ACTIVE_CONTEXT() not fail. TODO: create a static fake method and use it... instead of 'mth' */
|
||||
|
||||
@ -2109,9 +2110,9 @@ TODO: overcome this problem - accept parameters....
|
||||
|
||||
/* emulate the message sending */
|
||||
#if defined(INVOKE_DIRECTLY)
|
||||
return activate_new_method (moo, mth, 0);
|
||||
return activate_new_method(moo, mth, 0);
|
||||
#else
|
||||
return activate_new_method (moo, mth, 2);
|
||||
return activate_new_method(moo, mth, 2);
|
||||
#endif
|
||||
|
||||
oops:
|
||||
@ -2555,7 +2556,7 @@ static moo_pfrc_t __block_value (moo_t* moo, moo_oop_context_t rcv_blkctx, moo_o
|
||||
|
||||
/* the receiver must be a block context */
|
||||
MOO_ASSERT (moo, MOO_CLASSOF(moo, rcv_blkctx) == moo->_block_context);
|
||||
if (rcv_blkctx->receiver_or_source != moo->_nil)
|
||||
if (rcv_blkctx->receiver_or_base != moo->_nil)
|
||||
{
|
||||
/* the 'source' field is not nil.
|
||||
* this block context has already been activated once.
|
||||
@ -2598,7 +2599,7 @@ static moo_pfrc_t __block_value (moo_t* moo, moo_oop_context_t rcv_blkctx, moo_o
|
||||
blkctx->ip = rcv_blkctx->ip; /* no MOO_STORE_OOP() as it's a small integer */
|
||||
blkctx->ntmprs = rcv_blkctx->ntmprs; /* no MOO_STORE_OOP() as it's a small integer */
|
||||
MOO_STORE_OOP (moo, &blkctx->method_or_nargs, rcv_blkctx->method_or_nargs);
|
||||
MOO_STORE_OOP (moo, &blkctx->receiver_or_source, (moo_oop_t)rcv_blkctx);
|
||||
MOO_STORE_OOP (moo, &blkctx->receiver_or_base, (moo_oop_t)rcv_blkctx);
|
||||
MOO_STORE_OOP (moo, &blkctx->home, rcv_blkctx->home);
|
||||
MOO_STORE_OOP (moo, (moo_oop_t*)&blkctx->origin, (moo_oop_t)rcv_blkctx->origin);
|
||||
#endif
|
||||
@ -5354,7 +5355,7 @@ static MOO_INLINE int do_return (moo_t* moo, moo_oob_t bcode, moo_oop_t return_v
|
||||
* this context can't get executed further. */
|
||||
MOO_ASSERT (moo, (moo_oop_t)moo->active_context->sender == moo->_nil);
|
||||
MOO_ASSERT (moo, MOO_CLASSOF(moo, moo->active_context) == moo->_method_context);
|
||||
MOO_ASSERT (moo, moo->active_context->receiver_or_source == moo->_nil);
|
||||
MOO_ASSERT (moo, moo->active_context->receiver_or_base == moo->_nil);
|
||||
MOO_ASSERT (moo, moo->active_context == moo->processor->active->initial_context);
|
||||
MOO_ASSERT (moo, moo->active_context->origin == moo->processor->active->initial_context->origin);
|
||||
MOO_ASSERT (moo, moo->active_context->origin == moo->active_context);
|
||||
@ -5453,7 +5454,7 @@ static MOO_INLINE int make_block (moo_t* moo)
|
||||
/* set the home context where it's defined */
|
||||
MOO_STORE_OOP (moo, &blkctx->home, (moo_oop_t)moo->active_context);
|
||||
/* no source for a base block context. */
|
||||
blkctx->receiver_or_source = moo->_nil;
|
||||
blkctx->receiver_or_base = moo->_nil;
|
||||
|
||||
MOO_STORE_OOP (moo, (moo_oop_t*)&blkctx->origin, (moo_oop_t)moo->active_context->origin);
|
||||
|
||||
@ -5541,8 +5542,8 @@ static int __execute (moo_t* moo)
|
||||
b1 = bcode & 0x7; /* low 3 bits */
|
||||
push_instvar:
|
||||
LOG_INST1 (moo, "push_instvar %zu", b1);
|
||||
MOO_ASSERT (moo, MOO_OBJ_GET_FLAGS_TYPE(moo->active_context->origin->receiver_or_source) == MOO_OBJ_TYPE_OOP);
|
||||
MOO_STACK_PUSH (moo, MOO_OBJ_GET_OOP_VAL(moo->active_context->origin->receiver_or_source, b1));
|
||||
MOO_ASSERT (moo, MOO_OBJ_GET_FLAGS_TYPE(moo->active_context->origin->receiver_or_base) == MOO_OBJ_TYPE_OOP);
|
||||
MOO_STACK_PUSH (moo, MOO_OBJ_GET_OOP_VAL(moo->active_context->origin->receiver_or_base, b1));
|
||||
NEXT_INST();
|
||||
|
||||
/* ------------------------------------------------- */
|
||||
@ -5561,8 +5562,8 @@ static int __execute (moo_t* moo)
|
||||
b1 = bcode & 0x7; /* low 3 bits */
|
||||
store_instvar:
|
||||
LOG_INST1 (moo, "store_into_instvar %zu", b1);
|
||||
MOO_ASSERT (moo, MOO_OBJ_GET_FLAGS_TYPE(moo->active_context->receiver_or_source) == MOO_OBJ_TYPE_OOP);
|
||||
MOO_STORE_OOP (moo, MOO_OBJ_GET_OOP_PTR(moo->active_context->origin->receiver_or_source, b1), MOO_STACK_GETTOP(moo));
|
||||
MOO_ASSERT (moo, MOO_OBJ_GET_FLAGS_TYPE(moo->active_context->receiver_or_base) == MOO_OBJ_TYPE_OOP);
|
||||
MOO_STORE_OOP (moo, MOO_OBJ_GET_OOP_PTR(moo->active_context->origin->receiver_or_base, b1), MOO_STACK_GETTOP(moo));
|
||||
NEXT_INST();
|
||||
|
||||
/* ------------------------------------------------- */
|
||||
@ -5580,8 +5581,8 @@ static int __execute (moo_t* moo)
|
||||
b1 = bcode & 0x7; /* low 3 bits */
|
||||
pop_into_instvar:
|
||||
LOG_INST1 (moo, "pop_into_instvar %zu", b1);
|
||||
MOO_ASSERT (moo, MOO_OBJ_GET_FLAGS_TYPE(moo->active_context->receiver_or_source) == MOO_OBJ_TYPE_OOP);
|
||||
MOO_STORE_OOP (moo, MOO_OBJ_GET_OOP_PTR(moo->active_context->origin->receiver_or_source, b1), MOO_STACK_GETTOP(moo));
|
||||
MOO_ASSERT (moo, MOO_OBJ_GET_FLAGS_TYPE(moo->active_context->receiver_or_base) == MOO_OBJ_TYPE_OOP);
|
||||
MOO_STORE_OOP (moo, MOO_OBJ_GET_OOP_PTR(moo->active_context->origin->receiver_or_base, b1), MOO_STACK_GETTOP(moo));
|
||||
MOO_STACK_POP (moo);
|
||||
NEXT_INST();
|
||||
|
||||
@ -6060,7 +6061,7 @@ static int __execute (moo_t* moo)
|
||||
|
||||
ON_INST(BCODE_PUSH_RECEIVER)
|
||||
LOG_INST0 (moo, "push_receiver");
|
||||
MOO_STACK_PUSH (moo, moo->active_context->origin->receiver_or_source);
|
||||
MOO_STACK_PUSH (moo, moo->active_context->origin->receiver_or_base);
|
||||
NEXT_INST();
|
||||
|
||||
ON_INST(BCODE_PUSH_NIL)
|
||||
@ -6092,8 +6093,8 @@ static int __execute (moo_t* moo)
|
||||
{
|
||||
register moo_oop_t c;
|
||||
LOG_INST0 (moo, "push_receiver_ns");
|
||||
c = (moo_oop_t)MOO_CLASSOF(moo, moo->active_context->origin->receiver_or_source);
|
||||
if (c == (moo_oop_t)moo->_class) c = moo->active_context->origin->receiver_or_source;
|
||||
c = (moo_oop_t)MOO_CLASSOF(moo, moo->active_context->origin->receiver_or_base);
|
||||
if (c == (moo_oop_t)moo->_class) c = moo->active_context->origin->receiver_or_base;
|
||||
MOO_STACK_PUSH (moo, (moo_oop_t)((moo_oop_class_t)c)->nsup);
|
||||
NEXT_INST();
|
||||
}
|
||||
@ -6308,7 +6309,7 @@ static int __execute (moo_t* moo)
|
||||
|
||||
ON_INST(BCODE_RETURN_RECEIVER)
|
||||
LOG_INST0 (moo, "return_receiver");
|
||||
return_value = moo->active_context->origin->receiver_or_source;
|
||||
return_value = moo->active_context->origin->receiver_or_base;
|
||||
handle_return:
|
||||
{
|
||||
int n;
|
||||
@ -6397,7 +6398,7 @@ static int __execute (moo_t* moo)
|
||||
blkctx->ntmprs = MOO_SMOOI_TO_OOP(ntmprs);
|
||||
|
||||
MOO_STORE_OOP (moo, &blkctx->home, (moo_oop_t)rctx);
|
||||
blkctx->receiver_or_source = moo->_nil;
|
||||
blkctx->receiver_or_base = moo->_nil;
|
||||
|
||||
/* [NOTE]
|
||||
* the origin of a method context is set to itself
|
||||
|
@ -735,7 +735,7 @@ struct moo_context_t
|
||||
* a base block context(created but not yet activated) has nil in this
|
||||
* field. if a block context is activated by 'value', it points
|
||||
* to the block context object used as a base for shallow-copy. */
|
||||
moo_oop_t receiver_or_source;
|
||||
moo_oop_t receiver_or_base;
|
||||
|
||||
/* it is set to nil for a method context.
|
||||
* for a block context, it points to the active context at the
|
||||
@ -744,12 +744,19 @@ struct moo_context_t
|
||||
* an activated block context copies this field from the source. */
|
||||
moo_oop_t home;
|
||||
|
||||
/* when a method context is created, it is set to itself. no change is
|
||||
* made when the method context is activated. when a block context is
|
||||
/* it points to the method context created of the method defining the code
|
||||
* of this context. a method context points to itself. a block context
|
||||
* points to the method context where it is created. another block context
|
||||
* created within the block context also points to the same method context.
|
||||
* ctx->origin: method context
|
||||
* ctx->origin->method_or_nargs: actual method containing byte codes pertaining to ctx.
|
||||
*
|
||||
* when a method context is created, it is set to itself. no change is
|
||||
* made when the method context is activated. when a base block context is
|
||||
* created (when MAKE_BLOCK or BLOCK_COPY is executed), it is set to the
|
||||
* origin of the active context. when the block context is shallow-copied
|
||||
* origin of the active context. when the base block context is shallow-copied
|
||||
* for activation (when it is sent 'value'), it is set to the origin of
|
||||
* the source block context. */
|
||||
* the base block context. */
|
||||
moo_oop_context_t origin;
|
||||
|
||||
/* variable indexed part - actual arguments and temporaries are placed here */
|
||||
|
Loading…
x
Reference in New Issue
Block a user