touched up code a bit
This commit is contained in:
parent
ce9db0e40d
commit
3d937334d8
@ -26,7 +26,7 @@
|
|||||||
|
|
||||||
#class(#pointer) Process(Object)
|
#class(#pointer) Process(Object)
|
||||||
{
|
{
|
||||||
#dcl initial active state prev next.
|
#dcl initial active state prev next sp.
|
||||||
|
|
||||||
#method new
|
#method new
|
||||||
{
|
{
|
||||||
|
@ -3838,18 +3838,6 @@ static int compile_message_expression (stix_t* stix, int to_super)
|
|||||||
}
|
}
|
||||||
while (1);
|
while (1);
|
||||||
|
|
||||||
#if 0
|
|
||||||
if (compile_keyword_message(stix, to_super) <= -1) return -1;
|
|
||||||
|
|
||||||
while (stix->c->tok.type == STIX_IOTOK_SEMICOLON)
|
|
||||||
{
|
|
||||||
printf ("\tpop_stacktop for cascading\n");
|
|
||||||
if (emit_byte_instruction(stix, CODE_POP_STACKTOP) <= -1) return -1;
|
|
||||||
GET_TOKEN (stix);
|
|
||||||
if (compile_keyword_message(stix, 0) <= -1) return -1;
|
|
||||||
}
|
|
||||||
#endif
|
|
||||||
|
|
||||||
done:
|
done:
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
@ -3862,6 +3850,8 @@ static int compile_basic_expression (stix_t* stix, const stix_oocs_t* ident, con
|
|||||||
int to_super;
|
int to_super;
|
||||||
|
|
||||||
if (compile_expression_primary(stix, ident, ident_loc, ident_dotted, &to_super) <= -1) return -1;
|
if (compile_expression_primary(stix, ident, ident_loc, ident_dotted, &to_super) <= -1) return -1;
|
||||||
|
|
||||||
|
#if 0
|
||||||
if (stix->c->tok.type != STIX_IOTOK_EOF &&
|
if (stix->c->tok.type != STIX_IOTOK_EOF &&
|
||||||
stix->c->tok.type != STIX_IOTOK_RBRACE &&
|
stix->c->tok.type != STIX_IOTOK_RBRACE &&
|
||||||
stix->c->tok.type != STIX_IOTOK_PERIOD &&
|
stix->c->tok.type != STIX_IOTOK_PERIOD &&
|
||||||
@ -3869,6 +3859,14 @@ static int compile_basic_expression (stix_t* stix, const stix_oocs_t* ident, con
|
|||||||
{
|
{
|
||||||
if (compile_message_expression(stix, to_super) <= -1) return -1;
|
if (compile_message_expression(stix, to_super) <= -1) return -1;
|
||||||
}
|
}
|
||||||
|
#else
|
||||||
|
if (stix->c->tok.type == STIX_IOTOK_IDENT ||
|
||||||
|
stix->c->tok.type == STIX_IOTOK_BINSEL ||
|
||||||
|
stix->c->tok.type == STIX_IOTOK_KEYWORD)
|
||||||
|
{
|
||||||
|
if (compile_message_expression(stix, to_super) <= -1) return -1;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
@ -106,7 +106,6 @@ static stix_oop_process_t make_process (stix_t* stix, stix_oop_context_t c)
|
|||||||
{
|
{
|
||||||
stix_oop_process_t proc;
|
stix_oop_process_t proc;
|
||||||
|
|
||||||
/* TODO: do something about the stack. */
|
|
||||||
stix_pushtmp (stix, (stix_oop_t*)&c);
|
stix_pushtmp (stix, (stix_oop_t*)&c);
|
||||||
proc = (stix_oop_process_t)stix_instantiate (stix, stix->_process, STIX_NULL, stix->option.dfl_procstk_size);
|
proc = (stix_oop_process_t)stix_instantiate (stix, stix->_process, STIX_NULL, stix->option.dfl_procstk_size);
|
||||||
stix_poptmp (stix);
|
stix_poptmp (stix);
|
||||||
@ -114,6 +113,7 @@ static stix_oop_process_t make_process (stix_t* stix, stix_oop_context_t c)
|
|||||||
|
|
||||||
proc->state = STIX_SMOOI_TO_OOP(0);
|
proc->state = STIX_SMOOI_TO_OOP(0);
|
||||||
proc->initial_context = c;
|
proc->initial_context = c;
|
||||||
|
proc->sp = STIX_SMOOI_TO_OOP(-1);
|
||||||
|
|
||||||
return proc;
|
return proc;
|
||||||
}
|
}
|
||||||
@ -516,12 +516,12 @@ TODO: overcome this problem
|
|||||||
|
|
||||||
/* the initial context starts the life of the entire VM
|
/* the initial context starts the life of the entire VM
|
||||||
* and is not really worked on except that it is used to call the
|
* and is not really worked on except that it is used to call the
|
||||||
* initial method. so it doesn't really require any extra stack space.
|
* initial method. so it doesn't really require any extra stack space. */
|
||||||
* TODO: verify this theory of mine. */
|
/* TODO: verify this theory of mine. */
|
||||||
stix->ip = 0;
|
stix->ip = 0;
|
||||||
stix->sp = -1;
|
stix->sp = -1;
|
||||||
|
|
||||||
ctx->origin = ctx;
|
ctx->origin = ctx; /* point to self */
|
||||||
ctx->method_or_nargs = (stix_oop_t)mth; /* fake. help SWITCH_ACTIVE_CONTEXT() not fail*/
|
ctx->method_or_nargs = (stix_oop_t)mth; /* fake. help SWITCH_ACTIVE_CONTEXT() not fail*/
|
||||||
|
|
||||||
/* [NOTE]
|
/* [NOTE]
|
||||||
@ -540,7 +540,7 @@ TODO: overcome this problem
|
|||||||
STORE_ACTIVE_SP (stix); /* stix->active_context->sp = STIX_SMOOI_TO_OOP(stix->sp) */
|
STORE_ACTIVE_SP (stix); /* stix->active_context->sp = STIX_SMOOI_TO_OOP(stix->sp) */
|
||||||
|
|
||||||
stix_pushtmp (stix, (stix_oop_t*)&mth);
|
stix_pushtmp (stix, (stix_oop_t*)&mth);
|
||||||
/* call start_initial_process() intead of start_new_process() */
|
/* call start_initial_process() instead of start_new_process() */
|
||||||
proc = start_initial_process (stix, ctx);
|
proc = start_initial_process (stix, ctx);
|
||||||
stix_poptmp (stix);
|
stix_poptmp (stix);
|
||||||
if (!proc) return -1;
|
if (!proc) return -1;
|
||||||
@ -899,6 +899,10 @@ static int prim_basic_at_put (stix_t* stix, stix_ooi_t nargs)
|
|||||||
|
|
||||||
static int __block_value (stix_t* stix, stix_ooi_t nargs, stix_ooi_t num_first_arg_elems, stix_oop_context_t* pblkctx)
|
static int __block_value (stix_t* stix, stix_ooi_t nargs, stix_ooi_t num_first_arg_elems, stix_oop_context_t* pblkctx)
|
||||||
{
|
{
|
||||||
|
/* prepare a new block context for activation.
|
||||||
|
* the receiver must be a block context which becomes the base
|
||||||
|
* for a new block context. */
|
||||||
|
|
||||||
stix_oop_context_t blkctx, org_blkctx;
|
stix_oop_context_t blkctx, org_blkctx;
|
||||||
stix_ooi_t local_ntmprs, i;
|
stix_ooi_t local_ntmprs, i;
|
||||||
stix_ooi_t actual_arg_count;
|
stix_ooi_t actual_arg_count;
|
||||||
@ -1036,6 +1040,12 @@ printf ("<<ENTERING BLOCK>>\n");
|
|||||||
|
|
||||||
static int prim_block_new_process (stix_t* stix, stix_ooi_t nargs)
|
static int prim_block_new_process (stix_t* stix, stix_ooi_t nargs)
|
||||||
{
|
{
|
||||||
|
/* create a new process from a block context.
|
||||||
|
* the receiver must be be a block.
|
||||||
|
* [ 1 + 2 ] newProcess.
|
||||||
|
* [ :a :b | a + b ] newProcess: #(1 2)
|
||||||
|
*/
|
||||||
|
|
||||||
int x;
|
int x;
|
||||||
stix_oop_context_t blkctx;
|
stix_oop_context_t blkctx;
|
||||||
stix_oop_process_t proc;
|
stix_oop_process_t proc;
|
||||||
@ -1055,6 +1065,8 @@ static int prim_block_new_process (stix_t* stix, stix_ooi_t nargs)
|
|||||||
xarg = ACTIVE_STACK_GETTOP(stix);
|
xarg = ACTIVE_STACK_GETTOP(stix);
|
||||||
if (!STIX_ISTYPEOF(stix,xarg,STIX_OBJ_TYPE_OOP))
|
if (!STIX_ISTYPEOF(stix,xarg,STIX_OBJ_TYPE_OOP))
|
||||||
{
|
{
|
||||||
|
/* the only optional argument must be an OOP-indexable
|
||||||
|
* object like an array */
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1064,35 +1076,15 @@ static int prim_block_new_process (stix_t* stix, stix_ooi_t nargs)
|
|||||||
/* this primitive creates a new process with a block as if the block
|
/* this primitive creates a new process with a block as if the block
|
||||||
* is sent the value message */
|
* is sent the value message */
|
||||||
x = __block_value (stix, nargs, num_first_arg_elems, &blkctx);
|
x = __block_value (stix, nargs, num_first_arg_elems, &blkctx);
|
||||||
if (x <= 0) return x; /* hard failure and soft failure */
|
if (x <= 0) return x; /* both hard failure and soft failure */
|
||||||
|
|
||||||
proc = make_process (stix, blkctx);
|
proc = make_process (stix, blkctx);
|
||||||
if (!proc) return -1; /* hard failure */ /* TOOD: can't this be a soft failure? */
|
if (!proc) return -1; /* hard failure */ /* TOOD: can't this be treated as a soft failure? */
|
||||||
|
|
||||||
/* __block_value() has popped all arguments and the receiver.
|
/* __block_value() has popped all arguments and the receiver.
|
||||||
* PUSH the return value instead of changing the stack top */
|
* PUSH the return value instead of changing the stack top */
|
||||||
ACTIVE_STACK_PUSH (stix, (stix_oop_t)proc);
|
ACTIVE_STACK_PUSH (stix, (stix_oop_t)proc);
|
||||||
return 1;
|
return 1;
|
||||||
|
|
||||||
#if 0
|
|
||||||
stix_oop_process_t proc;
|
|
||||||
stix_oop_context_t rcv;
|
|
||||||
|
|
||||||
rcv = (stix_oop_context_t)ACTIVE_STACK_GETTOP(stix);
|
|
||||||
if (STIX_CLASSOF(stix, rcv) != stix->_block_context)
|
|
||||||
{
|
|
||||||
#if defined(STIX_DEBUG_EXEC)
|
|
||||||
printf ("PRIMITVE VALUE RECEIVER IS NOT A BLOCK CONTEXT\n");
|
|
||||||
#endif
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
proc = make_process (stix, rcv);
|
|
||||||
if (!proc) return -1; /* hard failure */ /* TOOD: can't this be a soft failure? */
|
|
||||||
|
|
||||||
ACTIVE_STACK_SETTOP (stix, (stix_oop_t)proc);
|
|
||||||
return 1;
|
|
||||||
#endif
|
|
||||||
}
|
}
|
||||||
|
|
||||||
static int prim_integer_add (stix_t* stix, stix_ooi_t nargs)
|
static int prim_integer_add (stix_t* stix, stix_ooi_t nargs)
|
||||||
@ -2352,6 +2344,8 @@ printf ("BCODE = %x\n", bcode);
|
|||||||
|
|
||||||
do
|
do
|
||||||
{
|
{
|
||||||
|
/* ntmprs contains the number of defined temporaries
|
||||||
|
* including those defined in the home context */
|
||||||
home_ntmprs = STIX_OOP_TO_SMOOI(((stix_oop_context_t)home)->ntmprs);
|
home_ntmprs = STIX_OOP_TO_SMOOI(((stix_oop_context_t)home)->ntmprs);
|
||||||
if (b1 >= home_ntmprs) break;
|
if (b1 >= home_ntmprs) break;
|
||||||
|
|
||||||
@ -2365,6 +2359,8 @@ printf ("BCODE = %x\n", bcode);
|
|||||||
}
|
}
|
||||||
while (1);
|
while (1);
|
||||||
|
|
||||||
|
/* bx is the actual index within the actual context
|
||||||
|
* containing the temporary */
|
||||||
bx = b1 - home_ntmprs;
|
bx = b1 - home_ntmprs;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -2376,7 +2372,7 @@ printf ("BCODE = %x\n", bcode);
|
|||||||
|
|
||||||
if ((bcode >> 4) & 1)
|
if ((bcode >> 4) & 1)
|
||||||
{
|
{
|
||||||
/* push - bit 4 on*/
|
/* push - bit 4 on */
|
||||||
DBGOUT_EXEC_1 ("PUSH_TEMPVAR %d", (int)b1);
|
DBGOUT_EXEC_1 ("PUSH_TEMPVAR %d", (int)b1);
|
||||||
ACTIVE_STACK_PUSH (stix, ctx->slot[bx]);
|
ACTIVE_STACK_PUSH (stix, ctx->slot[bx]);
|
||||||
}
|
}
|
||||||
@ -2836,7 +2832,7 @@ printf ("<<LEAVING>> SP=%d\n", (int)stix->sp);
|
|||||||
|
|
||||||
if (stix->processor->active->initial_context == stix->active_context)
|
if (stix->processor->active->initial_context == stix->active_context)
|
||||||
{
|
{
|
||||||
/* TODO: terminate a proces... */
|
/* TODO: terminate a process... */
|
||||||
printf ("TERMINATING XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX\n");
|
printf ("TERMINATING XXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXXX\n");
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
@ -2895,12 +2891,11 @@ printf ("TERMINATE A PROCESS............\n");
|
|||||||
STIX_ASSERT (b1 >= 0);
|
STIX_ASSERT (b1 >= 0);
|
||||||
STIX_ASSERT (b2 >= b1);
|
STIX_ASSERT (b2 >= b1);
|
||||||
|
|
||||||
/* the block context object created here is used
|
/* the block context object created here is used as a base
|
||||||
* as a base object for block context activation.
|
* object for block context activation. prim_block_value()
|
||||||
* prim_block_value() clones a block
|
* clones a block context and activates the cloned context.
|
||||||
* context and activates the cloned context.
|
* this base block context is created with no stack for
|
||||||
* this base block context is created with no
|
* this reason */
|
||||||
* stack for this reason. */
|
|
||||||
blkctx = (stix_oop_context_t)stix_instantiate (stix, stix->_block_context, STIX_NULL, 0);
|
blkctx = (stix_oop_context_t)stix_instantiate (stix, stix->_block_context, STIX_NULL, 0);
|
||||||
if (!blkctx) return -1;
|
if (!blkctx) return -1;
|
||||||
|
|
||||||
@ -2909,8 +2904,8 @@ printf ("TERMINATE A PROCESS............\n");
|
|||||||
* depending on STIX_BCODE_LONG_PARAM_SIZE. change 'ip' to point to
|
* depending on STIX_BCODE_LONG_PARAM_SIZE. change 'ip' to point to
|
||||||
* the instruction after the jump. */
|
* the instruction after the jump. */
|
||||||
blkctx->ip = STIX_SMOOI_TO_OOP(stix->ip + STIX_BCODE_LONG_PARAM_SIZE + 1);
|
blkctx->ip = STIX_SMOOI_TO_OOP(stix->ip + STIX_BCODE_LONG_PARAM_SIZE + 1);
|
||||||
/* stack pointer below the bottom. this block context has an
|
/* stack pointer below the bottom. this base block context
|
||||||
* empty stack anyway. */
|
* has an empty stack anyway. */
|
||||||
blkctx->sp = STIX_SMOOI_TO_OOP(-1);
|
blkctx->sp = STIX_SMOOI_TO_OOP(-1);
|
||||||
/* the number of arguments for a block context is local to the block */
|
/* the number of arguments for a block context is local to the block */
|
||||||
blkctx->method_or_nargs = STIX_SMOOI_TO_OOP(b1);
|
blkctx->method_or_nargs = STIX_SMOOI_TO_OOP(b1);
|
||||||
@ -2918,11 +2913,14 @@ printf ("TERMINATE A PROCESS............\n");
|
|||||||
* the number of temporaries of a home context */
|
* the number of temporaries of a home context */
|
||||||
blkctx->ntmprs = STIX_SMOOI_TO_OOP(b2);
|
blkctx->ntmprs = STIX_SMOOI_TO_OOP(b2);
|
||||||
|
|
||||||
|
/* set the home context where it's defined */
|
||||||
blkctx->home = (stix_oop_t)stix->active_context;
|
blkctx->home = (stix_oop_t)stix->active_context;
|
||||||
blkctx->receiver_or_source = stix->_nil; /* no source */
|
/* no source for a base block context. */
|
||||||
|
blkctx->receiver_or_source = stix->_nil;
|
||||||
|
|
||||||
blkctx->origin = stix->active_context->origin;
|
blkctx->origin = stix->active_context->origin;
|
||||||
|
|
||||||
|
/* push the new block context to the stack of the active context */
|
||||||
ACTIVE_STACK_PUSH (stix, (stix_oop_t)blkctx);
|
ACTIVE_STACK_PUSH (stix, (stix_oop_t)blkctx);
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
@ -449,6 +449,8 @@ int main (int argc, char* argv[])
|
|||||||
stix_setoption (stix, STIX_SYMTAB_SIZE, &tab_size);
|
stix_setoption (stix, STIX_SYMTAB_SIZE, &tab_size);
|
||||||
tab_size = 5000;
|
tab_size = 5000;
|
||||||
stix_setoption (stix, STIX_SYSDIC_SIZE, &tab_size);
|
stix_setoption (stix, STIX_SYSDIC_SIZE, &tab_size);
|
||||||
|
tab_size = 5000;
|
||||||
|
stix_setoption (stix, STIX_PROCSTK_SIZE, &tab_size);
|
||||||
}
|
}
|
||||||
|
|
||||||
{
|
{
|
||||||
|
@ -89,6 +89,10 @@ int stix_init (stix_t* stix, stix_mmgr_t* mmgr, stix_oow_t heapsz, const stix_vm
|
|||||||
stix->mmgr = mmgr;
|
stix->mmgr = mmgr;
|
||||||
stix->vmprim = *vmprim;
|
stix->vmprim = *vmprim;
|
||||||
|
|
||||||
|
stix->option.dfl_symtab_size = STIX_DFL_SYMTAB_SIZE;
|
||||||
|
stix->option.dfl_sysdic_size = STIX_DFL_SYSDIC_SIZE;
|
||||||
|
stix->option.dfl_procstk_size = STIX_DFL_PROCSTK_SIZE;
|
||||||
|
|
||||||
/*stix->permheap = stix_makeheap (stix, what is the best size???);
|
/*stix->permheap = stix_makeheap (stix, what is the best size???);
|
||||||
if (!stix->curheap) goto oops; */
|
if (!stix->curheap) goto oops; */
|
||||||
stix->curheap = stix_makeheap (stix, heapsz);
|
stix->curheap = stix_makeheap (stix, heapsz);
|
||||||
@ -171,18 +175,40 @@ int stix_setoption (stix_t* stix, stix_option_t id, const void* value)
|
|||||||
return 0;
|
return 0;
|
||||||
|
|
||||||
case STIX_SYMTAB_SIZE:
|
case STIX_SYMTAB_SIZE:
|
||||||
|
{
|
||||||
|
stix_oow_t w;
|
||||||
|
|
||||||
|
w = *(stix_oow_t*)value;
|
||||||
|
if (w <= 0 || w > STIX_SMOOI_MAX) goto einval;
|
||||||
|
|
||||||
stix->option.dfl_symtab_size = *(stix_oow_t*)value;
|
stix->option.dfl_symtab_size = *(stix_oow_t*)value;
|
||||||
return 0;
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
case STIX_SYSDIC_SIZE:
|
case STIX_SYSDIC_SIZE:
|
||||||
|
{
|
||||||
|
stix_oow_t w;
|
||||||
|
|
||||||
|
w = *(stix_oow_t*)value;
|
||||||
|
if (w <= 0 || w > STIX_SMOOI_MAX) goto einval;
|
||||||
|
|
||||||
stix->option.dfl_sysdic_size = *(stix_oow_t*)value;
|
stix->option.dfl_sysdic_size = *(stix_oow_t*)value;
|
||||||
return 0;
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
case STIX_PROCSTK_SIZE:
|
case STIX_PROCSTK_SIZE:
|
||||||
|
{
|
||||||
|
stix_oow_t w;
|
||||||
|
|
||||||
|
w = *(stix_oow_t*)value;
|
||||||
|
if (w <= 0 || w > STIX_SMOOI_MAX) goto einval;
|
||||||
|
|
||||||
stix->option.dfl_procstk_size = *(stix_oow_t*)value;
|
stix->option.dfl_procstk_size = *(stix_oow_t*)value;
|
||||||
return 0;
|
return 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
einval:
|
||||||
stix->errnum = STIX_EINVAL;
|
stix->errnum = STIX_EINVAL;
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
@ -71,6 +71,14 @@ enum stix_option_t
|
|||||||
};
|
};
|
||||||
typedef enum stix_option_t stix_option_t;
|
typedef enum stix_option_t stix_option_t;
|
||||||
|
|
||||||
|
enum stix_option_dflval_t
|
||||||
|
{
|
||||||
|
STIX_DFL_SYMTAB_SIZE = 5000,
|
||||||
|
STIX_DFL_SYSDIC_SIZE = 5000,
|
||||||
|
STIX_DFL_PROCSTK_SIZE = 5000
|
||||||
|
};
|
||||||
|
typedef enum stix_option_dflval_t stix_option_dflval_t;
|
||||||
|
|
||||||
enum stix_trait_t
|
enum stix_trait_t
|
||||||
{
|
{
|
||||||
/* perform no garbage collection when the heap is full.
|
/* perform no garbage collection when the heap is full.
|
||||||
@ -502,31 +510,31 @@ struct stix_context_t
|
|||||||
stix_oop_t method_or_nargs;
|
stix_oop_t method_or_nargs;
|
||||||
|
|
||||||
/* it points to the receiver of the message for a method context.
|
/* it points to the receiver of the message for a method context.
|
||||||
* a block context created but not yet activated has nil in this
|
* a base block context(created but not yet activated) has nil in this
|
||||||
* field. if a block context is activated by 'value', it points
|
* field. if a block context is activated by 'value', it points
|
||||||
* to the block context object used as a base for shallow-copy. */
|
* to the block context object used as a base for shallow-copy. */
|
||||||
stix_oop_t receiver_or_source;
|
stix_oop_t receiver_or_source;
|
||||||
|
|
||||||
/* it is set to nil for a method context.
|
/* it is set to nil for a method context.
|
||||||
* for a block context, it points to the active context at the
|
* for a block context, it points to the active context at the
|
||||||
* moment the block context was created. that is, it ponts to
|
* moment the block context was created. that is, it points to
|
||||||
* a method context where the block has been defined. an activated
|
* a method context where the base block has been defined.
|
||||||
* block context copies this field from the source. */
|
* an activated block context copies this field from the source. */
|
||||||
stix_oop_t home;
|
stix_oop_t home;
|
||||||
|
|
||||||
/* when a method context is created, it is set to itself.
|
/* when a method context is created, it is set to itself. no change is
|
||||||
* no change is made when the method context is activated.
|
* made when the method context is activated. when a block context is
|
||||||
* when a block context is created, it is set to the origin
|
* created (when MAKE_BLOCK or BLOCK_COPY is executed), it is set to the
|
||||||
* of the active context. when the block context is shallow-copied
|
* origin of the active context. when the block context is shallow-copied
|
||||||
* for activation, it is set to the origin of the source block contxt. */
|
* for activation (when it is sent 'value'), it is set to the origin of
|
||||||
|
* the source block context. */
|
||||||
stix_oop_context_t origin;
|
stix_oop_context_t origin;
|
||||||
|
|
||||||
/* variable indexed part */
|
/* variable indexed part */
|
||||||
stix_oop_t slot[1]; /* stack */
|
stix_oop_t slot[1]; /* stack */
|
||||||
};
|
};
|
||||||
|
|
||||||
|
#define STIX_PROCESS_NAMED_INSTVARS 6
|
||||||
#define STIX_PROCESS_NAMED_INSTVARS 5
|
|
||||||
typedef struct stix_process_t stix_process_t;
|
typedef struct stix_process_t stix_process_t;
|
||||||
typedef struct stix_process_t* stix_oop_process_t;
|
typedef struct stix_process_t* stix_oop_process_t;
|
||||||
struct stix_process_t
|
struct stix_process_t
|
||||||
@ -538,6 +546,9 @@ struct stix_process_t
|
|||||||
stix_oop_process_t prev;
|
stix_oop_process_t prev;
|
||||||
stix_oop_process_t next;
|
stix_oop_process_t next;
|
||||||
|
|
||||||
|
/* stack pointer. SmallInteger */
|
||||||
|
stix_oop_t sp;
|
||||||
|
|
||||||
/* == variable indexed part == */
|
/* == variable indexed part == */
|
||||||
stix_oop_t slot[1]; /* process stack */
|
stix_oop_t slot[1]; /* process stack */
|
||||||
};
|
};
|
||||||
|
Loading…
x
Reference in New Issue
Block a user