bc: rename BcInstPtr::idx and ::len

Signed-off-by: Denys Vlasenko <vda.linux@googlemail.com>
This commit is contained in:
Denys Vlasenko 2018-12-21 23:01:26 +01:00
parent 8287b1c869
commit 24e4194635

View File

@ -388,8 +388,8 @@ typedef struct BcResult {
typedef struct BcInstPtr { typedef struct BcInstPtr {
size_t func; size_t func;
size_t idx; size_t inst_idx;
IF_BC(size_t len;) IF_BC(size_t results_len_before_call;)
} BcInstPtr; } BcInstPtr;
// BC_LEX_NEG is not used in lexing; it is only for parsing. // BC_LEX_NEG is not used in lexing; it is only for parsing.
@ -3600,7 +3600,7 @@ static void bc_program_reset(void)
f = bc_program_func_BC_PROG_MAIN(); f = bc_program_func_BC_PROG_MAIN();
ip = bc_vec_top(&G.prog.exestack); ip = bc_vec_top(&G.prog.exestack);
ip->idx = f->code.len; ip->inst_idx = f->code.len;
} }
// Called when zbc/zdc_parse_parse() detects a failure, // Called when zbc/zdc_parse_parse() detects a failure,
@ -5252,8 +5252,8 @@ static BC_STATUS zbc_program_read(void)
} }
ip.func = BC_PROG_READ; ip.func = BC_PROG_READ;
ip.idx = 0; ip.inst_idx = 0;
IF_BC(ip.len = G.prog.results.len;) IF_BC(ip.results_len_before_call = G.prog.results.len;)
// Update this pointer, just in case. // Update this pointer, just in case.
f = bc_program_func(BC_PROG_READ); f = bc_program_func(BC_PROG_READ);
@ -5945,7 +5945,7 @@ static BC_STATUS zbc_program_call(char *code, size_t *idx)
BcResult *arg; BcResult *arg;
nparams = bc_program_index(code, idx); nparams = bc_program_index(code, idx);
ip.idx = 0; ip.inst_idx = 0;
ip.func = bc_program_index(code, idx); ip.func = bc_program_index(code, idx);
func = bc_program_func(ip.func); func = bc_program_func(ip.func);
@ -5955,7 +5955,7 @@ static BC_STATUS zbc_program_call(char *code, size_t *idx)
if (nparams != func->nparams) { if (nparams != func->nparams) {
RETURN_STATUS(bc_error_fmt("function has %u parameters, but called with %u", func->nparams, nparams)); RETURN_STATUS(bc_error_fmt("function has %u parameters, but called with %u", func->nparams, nparams));
} }
ip.len = G.prog.results.len - nparams; ip.results_len_before_call = G.prog.results.len - nparams;
for (i = 0; i < nparams; ++i) { for (i = 0; i < nparams; ++i) {
BcStatus s; BcStatus s;
@ -6000,7 +6000,7 @@ static BC_STATUS zbc_program_return(char inst)
size_t i; size_t i;
BcInstPtr *ip = bc_vec_top(&G.prog.exestack); BcInstPtr *ip = bc_vec_top(&G.prog.exestack);
if (!STACK_HAS_EQUAL_OR_MORE_THAN(&G.prog.results, ip->len + (inst == BC_INST_RET))) if (!STACK_HAS_EQUAL_OR_MORE_THAN(&G.prog.results, ip->results_len_before_call + (inst == BC_INST_RET)))
RETURN_STATUS(bc_error_stack_has_too_few_elements()); RETURN_STATUS(bc_error_stack_has_too_few_elements());
f = bc_program_func(ip->func); f = bc_program_func(ip->func);
@ -6028,7 +6028,7 @@ static BC_STATUS zbc_program_return(char inst)
bc_vec_pop(v); bc_vec_pop(v);
} }
bc_vec_npop(&G.prog.results, G.prog.results.len - ip->len); bc_vec_npop(&G.prog.results, G.prog.results.len - ip->results_len_before_call);
bc_vec_push(&G.prog.results, &res); bc_vec_push(&G.prog.results, &res);
bc_vec_pop(&G.prog.exestack); bc_vec_pop(&G.prog.exestack);
@ -6391,8 +6391,7 @@ static BC_STATUS zdc_program_execStr(char *code, size_t *bgn, bool cond)
bc_parse_free(&prs); bc_parse_free(&prs);
} }
ip.idx = 0; ip.inst_idx = 0;
IF_BC(ip.len = G.prog.results.len;)
ip.func = fidx; ip.func = fidx;
bc_vec_pop(&G.prog.results); bc_vec_pop(&G.prog.results);
@ -6433,12 +6432,12 @@ static BC_STATUS zbc_program_exec(void)
char *code = func->code.v; char *code = func->code.v;
dbg_exec("func:%zd bytes:%zd ip:%zd results.len:%d", dbg_exec("func:%zd bytes:%zd ip:%zd results.len:%d",
ip->func, func->code.len, ip->idx, G.prog.results.len); ip->func, func->code.len, ip->inst_idx, G.prog.results.len);
while (ip->idx < func->code.len) { while (ip->inst_idx < func->code.len) {
BcStatus s = BC_STATUS_SUCCESS; BcStatus s = BC_STATUS_SUCCESS;
char inst = code[ip->idx++]; char inst = code[ip->inst_idx++];
dbg_exec("inst at %zd:%d results.len:%d", ip->idx - 1, inst, G.prog.results.len); dbg_exec("inst at %zd:%d results.len:%d", ip->inst_idx - 1, inst, G.prog.results.len);
switch (inst) { switch (inst) {
#if ENABLE_BC #if ENABLE_BC
case BC_INST_JUMP_ZERO: { case BC_INST_JUMP_ZERO: {
@ -6449,21 +6448,21 @@ static BC_STATUS zbc_program_exec(void)
zero = (bc_num_cmp(num, &G.prog.zero) == 0); zero = (bc_num_cmp(num, &G.prog.zero) == 0);
bc_vec_pop(&G.prog.results); bc_vec_pop(&G.prog.results);
if (!zero) { if (!zero) {
bc_program_index(code, &ip->idx); bc_program_index(code, &ip->inst_idx);
break; break;
} }
// else: fall through // else: fall through
} }
case BC_INST_JUMP: { case BC_INST_JUMP: {
size_t idx = bc_program_index(code, &ip->idx); size_t idx = bc_program_index(code, &ip->inst_idx);
size_t *addr = bc_vec_item(&func->labels, idx); size_t *addr = bc_vec_item(&func->labels, idx);
dbg_exec("BC_INST_JUMP: to %ld", (long)*addr); dbg_exec("BC_INST_JUMP: to %ld", (long)*addr);
ip->idx = *addr; ip->inst_idx = *addr;
break; break;
} }
case BC_INST_CALL: case BC_INST_CALL:
dbg_exec("BC_INST_CALL:"); dbg_exec("BC_INST_CALL:");
s = zbc_program_call(code, &ip->idx); s = zbc_program_call(code, &ip->inst_idx);
goto read_updated_ip; goto read_updated_ip;
case BC_INST_INC_PRE: case BC_INST_INC_PRE:
case BC_INST_DEC_PRE: case BC_INST_DEC_PRE:
@ -6499,12 +6498,12 @@ static BC_STATUS zbc_program_exec(void)
goto read_updated_ip; goto read_updated_ip;
case BC_INST_VAR: case BC_INST_VAR:
dbg_exec("BC_INST_VAR:"); dbg_exec("BC_INST_VAR:");
s = zbc_program_pushVar(code, &ip->idx, false, false); s = zbc_program_pushVar(code, &ip->inst_idx, false, false);
break; break;
case BC_INST_ARRAY_ELEM: case BC_INST_ARRAY_ELEM:
case BC_INST_ARRAY: case BC_INST_ARRAY:
dbg_exec("BC_INST_ARRAY[_ELEM]:"); dbg_exec("BC_INST_ARRAY[_ELEM]:");
s = zbc_program_pushArray(code, &ip->idx, inst); s = zbc_program_pushArray(code, &ip->inst_idx, inst);
break; break;
case BC_INST_LAST: case BC_INST_LAST:
r.t = BC_RESULT_LAST; r.t = BC_RESULT_LAST;
@ -6524,7 +6523,7 @@ static BC_STATUS zbc_program_exec(void)
case BC_INST_NUM: case BC_INST_NUM:
dbg_exec("BC_INST_NUM:"); dbg_exec("BC_INST_NUM:");
r.t = BC_RESULT_CONSTANT; r.t = BC_RESULT_CONSTANT;
r.d.id.idx = bc_program_index(code, &ip->idx); r.d.id.idx = bc_program_index(code, &ip->inst_idx);
bc_vec_push(&G.prog.results, &r); bc_vec_push(&G.prog.results, &r);
break; break;
case BC_INST_POP: case BC_INST_POP:
@ -6547,7 +6546,7 @@ static BC_STATUS zbc_program_exec(void)
case BC_INST_STR: case BC_INST_STR:
dbg_exec("BC_INST_STR:"); dbg_exec("BC_INST_STR:");
r.t = BC_RESULT_STR; r.t = BC_RESULT_STR;
r.d.id.idx = bc_program_index(code, &ip->idx); r.d.id.idx = bc_program_index(code, &ip->inst_idx);
bc_vec_push(&G.prog.results, &r); bc_vec_push(&G.prog.results, &r);
break; break;
case BC_INST_POWER: case BC_INST_POWER:
@ -6594,7 +6593,7 @@ static BC_STATUS zbc_program_exec(void)
break; break;
case BC_INST_EXECUTE: case BC_INST_EXECUTE:
case BC_INST_EXEC_COND: case BC_INST_EXEC_COND:
s = zdc_program_execStr(code, &ip->idx, inst == BC_INST_EXEC_COND); s = zdc_program_execStr(code, &ip->inst_idx, inst == BC_INST_EXEC_COND);
goto read_updated_ip; goto read_updated_ip;
case BC_INST_PRINT_STACK: { case BC_INST_PRINT_STACK: {
size_t idx; size_t idx;
@ -6637,11 +6636,11 @@ static BC_STATUS zbc_program_exec(void)
case BC_INST_LOAD: case BC_INST_LOAD:
case BC_INST_PUSH_VAR: { case BC_INST_PUSH_VAR: {
bool copy = inst == BC_INST_LOAD; bool copy = inst == BC_INST_LOAD;
s = zbc_program_pushVar(code, &ip->idx, true, copy); s = zbc_program_pushVar(code, &ip->inst_idx, true, copy);
break; break;
} }
case BC_INST_PUSH_TO_VAR: { case BC_INST_PUSH_TO_VAR: {
char *name = bc_program_name(code, &ip->idx); char *name = bc_program_name(code, &ip->inst_idx);
s = zbc_program_copyToVar(name, true); s = zbc_program_copyToVar(name, true);
free(name); free(name);
break; break;
@ -6661,7 +6660,7 @@ static BC_STATUS zbc_program_exec(void)
ip = bc_vec_top(&G.prog.exestack); ip = bc_vec_top(&G.prog.exestack);
func = bc_program_func(ip->func); func = bc_program_func(ip->func);
code = func->code.v; code = func->code.v;
dbg_exec("func:%zd bytes:%zd ip:%zd", ip->func, func->code.len, ip->idx); dbg_exec("func:%zd bytes:%zd ip:%zd", ip->func, func->code.len, ip->inst_idx);
} }
if (s || G_interrupt) { if (s || G_interrupt) {
@ -6731,11 +6730,11 @@ static BC_STATUS zbc_vm_process(const char *text)
if (ip->func != BC_PROG_MAIN) if (ip->func != BC_PROG_MAIN)
bb_error_msg_and_die("BUG:not MAIN"); bb_error_msg_and_die("BUG:not MAIN");
#endif #endif
//bb_error_msg("ip->func:%d >idx:%d >len:%d", ip->func, ip->idx, ip->len); //bb_error_msg("ip->func:%d >idx:%d >len:%d", ip->func, ip->inst_idx, ip->len);
f = bc_program_func_BC_PROG_MAIN(); f = bc_program_func_BC_PROG_MAIN();
//bb_error_msg("MAIN->code.len:%d >strs.len:%d >consts.len:%d", f->code.len, f->strs.len, f->consts.len); // labels, autos, nparams //bb_error_msg("MAIN->code.len:%d >strs.len:%d >consts.len:%d", f->code.len, f->strs.len, f->consts.len); // labels, autos, nparams
bc_vec_pop_all(&f->code); bc_vec_pop_all(&f->code);
ip->idx = 0; ip->inst_idx = 0;
IF_BC(bc_vec_pop_all(&f->strs);) IF_BC(bc_vec_pop_all(&f->strs);)
IF_BC(bc_vec_pop_all(&f->consts);) IF_BC(bc_vec_pop_all(&f->consts);)
} }