summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorStephen Dolan <mu@netsoc.tcd.ie>2013-06-18 01:07:18 +0100
committerStephen Dolan <mu@netsoc.tcd.ie>2013-06-18 01:07:18 +0100
commit824ce76cecd11863f6c86cf04e3a56075cbcd30a (patch)
treec1cff96b8d5e0464a11de677c9e7827d5f6b578c
parent2a18f97d12d48dcf92fbbfb15aea0fd02f763283 (diff)
Simplify block functions for variables
-rw-r--r--builtin.c10
-rw-r--r--compile.c61
-rw-r--r--compile.h7
-rw-r--r--parser.y18
4 files changed, 43 insertions, 53 deletions
diff --git a/builtin.c b/builtin.c
index 60be1bcc..a2adb1ac 100644
--- a/builtin.c
+++ b/builtin.c
@@ -528,20 +528,18 @@ static block bind_bytecoded_builtins(block b) {
};
for (unsigned i=0; i<sizeof(builtin_def_1arg)/sizeof(builtin_def_1arg[0]); i++) {
builtins = BLOCK(builtins, gen_function(builtin_def_1arg[i].name,
- gen_op_block_unbound(CLOSURE_PARAM, "arg"),
+ gen_param("arg"),
builtin_def_1arg[i].code));
}
}
{
- block rangevar = block_bind(gen_op_var_unbound(STOREV, "rangevar"),
- gen_noop(), OP_HAS_VARIABLE);
+ block rangevar = gen_op_var_fresh(STOREV, "rangevar");
block init = BLOCK(gen_op_simple(DUP), gen_call("start", gen_noop()), rangevar);
block range = BLOCK(init,
gen_call("end", gen_noop()),
- gen_op_var_bound(RANGE, rangevar));
+ gen_op_bound(RANGE, rangevar));
builtins = BLOCK(builtins, gen_function("range",
- BLOCK(gen_op_block_unbound(CLOSURE_PARAM, "start"),
- gen_op_block_unbound(CLOSURE_PARAM, "end")),
+ BLOCK(gen_param("start"), gen_param("end")),
range));
}
diff --git a/compile.c b/compile.c
index bf4f92fd..4dda1011 100644
--- a/compile.c
+++ b/compile.c
@@ -153,34 +153,27 @@ void inst_set_target(block b, block target) {
b.first->imm.target = target.last;
}
-block gen_op_var_unbound(opcode op, const char* name) {
- assert(opcode_describe(op)->flags & OP_HAS_VARIABLE);
+block gen_op_unbound(opcode op, const char* name) {
+ assert(opcode_describe(op)->flags & OP_HAS_BINDING);
inst* i = inst_new(op);
i->symbol = strdup(name);
return inst_block(i);
}
-block gen_op_var_bound(opcode op, block binder) {
- assert(block_is_single(binder));
- block b = gen_op_var_unbound(op, binder.first->symbol);
- b.first->bound_by = binder.first;
- return b;
-}
-
-block gen_op_block_unbound(opcode op, const char* name) {
- assert(opcode_describe(op)->flags & OP_IS_CALL_PSEUDO);
- inst* i = inst_new(op);
- i->symbol = strdup(name);
- return inst_block(i);
+block gen_op_var_fresh(opcode op, const char* name) {
+ assert(opcode_describe(op)->flags & OP_HAS_VARIABLE);
+ return block_bind(gen_op_unbound(op, name),
+ gen_noop(), OP_HAS_VARIABLE);
}
-block gen_op_block_bound(opcode op, block binder) {
+block gen_op_bound(opcode op, block binder) {
assert(block_is_single(binder));
- block b = gen_op_block_unbound(op, binder.first->symbol);
+ block b = gen_op_unbound(op, binder.first->symbol);
b.first->bound_by = binder.first;
return b;
}
+
static void inst_join(inst* a, inst* b) {
assert(a && b);
assert(!a->next);
@@ -280,12 +273,16 @@ block gen_function(const char* name, block formals, block body) {
return b;
}
+block gen_param(const char* name) {
+ return gen_op_unbound(CLOSURE_PARAM, name);
+}
+
block gen_lambda(block body) {
return gen_function("@lambda", gen_noop(), body);
}
block gen_call(const char* name, block args) {
- block b = gen_op_block_unbound(CALL_JQ, name);
+ block b = gen_op_unbound(CALL_JQ, name);
b.first->arglist = args;
return b;
}
@@ -306,30 +303,27 @@ block gen_both(block a, block b) {
block gen_collect(block expr) {
- block array_var = block_bind(gen_op_var_unbound(STOREV, "collect"),
- gen_noop(), OP_HAS_VARIABLE);
+ block array_var = gen_op_var_fresh(STOREV, "collect");
block c = BLOCK(gen_op_simple(DUP), gen_const(jv_array()), array_var);
- block tail = BLOCK(gen_op_var_bound(APPEND, array_var),
+ block tail = BLOCK(gen_op_bound(APPEND, array_var),
gen_op_simple(BACKTRACK));
return BLOCK(c,
gen_op_target(FORK, tail),
expr,
tail,
- gen_op_var_bound(LOADVN, array_var));
+ gen_op_bound(LOADVN, array_var));
}
block gen_reduce(const char* varname, block source, block init, block body) {
- block res_var = block_bind(gen_op_var_unbound(STOREV, "reduce"),
- gen_noop(), OP_HAS_VARIABLE);
-
+ block res_var = gen_op_var_fresh(STOREV, "reduce");
block loop = BLOCK(gen_op_simple(DUP),
source,
- block_bind(gen_op_var_unbound(STOREV, varname),
- BLOCK(gen_op_var_bound(LOADVN, res_var),
+ block_bind(gen_op_unbound(STOREV, varname),
+ BLOCK(gen_op_bound(LOADVN, res_var),
body,
- gen_op_var_bound(STOREV, res_var)),
+ gen_op_bound(STOREV, res_var)),
OP_HAS_VARIABLE),
gen_op_simple(BACKTRACK));
return BLOCK(gen_op_simple(DUP),
@@ -337,19 +331,18 @@ block gen_reduce(const char* varname, block source, block init, block body) {
res_var,
gen_op_target(FORK, loop),
loop,
- gen_op_var_bound(LOADVN, res_var));
+ gen_op_bound(LOADVN, res_var));
}
block gen_definedor(block a, block b) {
// var found := false
- block found_var = block_bind(gen_op_var_unbound(STOREV, "found"),
- gen_noop(), OP_HAS_VARIABLE);
+ block found_var = gen_op_var_fresh(STOREV, "found");
block init = BLOCK(gen_op_simple(DUP), gen_const(jv_false()), found_var);
// if found, backtrack. Otherwise execute b
block backtrack = gen_op_simple(BACKTRACK);
block tail = BLOCK(gen_op_simple(DUP),
- gen_op_var_bound(LOADV, found_var),
+ gen_op_bound(LOADV, found_var),
gen_op_target(JUMP_F, backtrack),
backtrack,
gen_op_simple(POP),
@@ -361,7 +354,7 @@ block gen_definedor(block a, block b) {
// found := true, produce result
block if_found = BLOCK(gen_op_simple(DUP),
gen_const(jv_true()),
- gen_op_var_bound(STOREV, found_var),
+ gen_op_bound(STOREV, found_var),
gen_op_target(JUMP, tail));
return BLOCK(init,
@@ -400,7 +393,7 @@ block gen_or(block a, block b) {
block gen_var_binding(block var, const char* name, block body) {
return BLOCK(gen_op_simple(DUP), var,
- block_bind(gen_op_var_unbound(STOREV, name),
+ block_bind(gen_op_unbound(STOREV, name),
body, OP_HAS_VARIABLE));
}
@@ -475,7 +468,7 @@ static int expand_call_arglist(struct locfile* locations, block* b) {
break;
case CLOSURE_CREATE:
block_append(&prelude, b);
- block_append(&callargs, gen_op_block_bound(CLOSURE_REF, b));
+ block_append(&callargs, gen_op_bound(CLOSURE_REF, b));
break;
}
actual_args++;
diff --git a/compile.h b/compile.h
index 152384a7..4ac7168b 100644
--- a/compile.h
+++ b/compile.h
@@ -24,11 +24,12 @@ block gen_noop();
block gen_op_simple(opcode op);
block gen_const(jv constant);
block gen_op_target(opcode op, block target);
-block gen_op_var_unbound(opcode op, const char* name);
-block gen_op_var_bound(opcode op, block binder);
-block gen_op_block_unbound(opcode op, const char* name);
+block gen_op_unbound(opcode op, const char* name);
+block gen_op_bound(opcode op, block binder);
+block gen_op_var_fresh(opcode op, const char* name);
block gen_function(const char* name, block formals, block body);
+block gen_param(const char* name);
block gen_lambda(block body);
block gen_call(const char* name, block body);
block gen_subexp(block a);
diff --git a/parser.y b/parser.y
index 8d451e9d..4ec10383 100644
--- a/parser.y
+++ b/parser.y
@@ -170,24 +170,22 @@ static block gen_format(block a, jv fmt) {
}
static block gen_definedor_assign(block object, block val) {
- block tmp = block_bind(gen_op_var_unbound(STOREV, "tmp"),
- gen_noop(), OP_HAS_VARIABLE);
+ block tmp = gen_op_var_fresh(STOREV, "tmp");
return BLOCK(gen_op_simple(DUP),
val, tmp,
gen_call("_modify", BLOCK(gen_lambda(object),
gen_lambda(gen_definedor(gen_noop(),
- gen_op_var_bound(LOADV, tmp))))));
+ gen_op_bound(LOADV, tmp))))));
}
static block gen_update(block object, block val, int optype) {
- block tmp = block_bind(gen_op_var_unbound(STOREV, "tmp"),
- gen_noop(), OP_HAS_VARIABLE);
+ block tmp = gen_op_var_fresh(STOREV, "tmp");
return BLOCK(gen_op_simple(DUP),
val,
tmp,
gen_call("_modify", BLOCK(gen_lambda(object),
gen_lambda(gen_binop(gen_noop(),
- gen_op_var_bound(LOADV, tmp),
+ gen_op_bound(LOADV, tmp),
optype)))));
}
@@ -337,7 +335,7 @@ FuncDef:
"def" IDENT '(' IDENT ')' ':' Exp ';' {
$$ = gen_function(jv_string_value($2),
- gen_op_block_unbound(CLOSURE_PARAM, jv_string_value($4)),
+ gen_param(jv_string_value($4)),
$7);
jv_free($2);
jv_free($4);
@@ -345,8 +343,8 @@ FuncDef:
"def" IDENT '(' IDENT ';' IDENT ')' ':' Exp ';' {
$$ = gen_function(jv_string_value($2),
- BLOCK(gen_op_block_unbound(CLOSURE_PARAM, jv_string_value($4)),
- gen_op_block_unbound(CLOSURE_PARAM, jv_string_value($6))),
+ BLOCK(gen_param(jv_string_value($4)),
+ gen_param(jv_string_value($6))),
$9);
jv_free($2);
jv_free($4);
@@ -459,7 +457,7 @@ FORMAT {
$$ = BLOCK(gen_subexp(gen_const(jv_object())), $2, gen_op_simple(POP));
} |
'$' IDENT {
- $$ = gen_location(@$, gen_op_var_unbound(LOADV, jv_string_value($2)));
+ $$ = gen_location(@$, gen_op_unbound(LOADV, jv_string_value($2)));
jv_free($2);
} |
IDENT {