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, argstr, expr) := (
sprint("double", funcname, "(", argstr, ") {"),
block2c(subst(pow, "^", optimize(expr))),
sprint("}", "
"))$
|