summaryrefslogtreecommitdiff
path: root/src/expr2c.mac
blob: dba598798d7c8344df3cac07d09a3bd6d946a62d (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
printdecl(vars) := (
	sprint("double", first(vars)),
	for v in rest(vars) do sprint(",", v),
	sprint(";"))$

printdef(expr) := sprint(first(expr), "=", second(expr), ";")$

block2c(expr) := 
	if ?equal(op(expr), block) then (
		printdecl(first(expr)),
		for d in reverse(rest(reverse(rest(expr)))) do printdef(d),
		sprint("return", string(last(expr)), ";}", "
"))
	else
		sprint("return", string(expr), ";}", "
")$

expr2c(funcname, args, expr) := (
	sprint("double", funcname, "(", args, ") {"),
	block2c(subst(pow, "^", optimize(expr))))$