Skip to content

Commit

Permalink
vala: merge eval_ast into eval, add DEBUG-EVAL
Browse files Browse the repository at this point in the history
  • Loading branch information
asarhaddon committed Oct 15, 2024
1 parent 9bf894c commit 77e0d68
Show file tree
Hide file tree
Showing 10 changed files with 300 additions and 438 deletions.
11 changes: 2 additions & 9 deletions impls/vala/env.vala
Original file line number Diff line number Diff line change
Expand Up @@ -59,18 +59,11 @@ class Mal.Env : GC.Object {
data[key] = f;
}

public Mal.Env? find(Mal.Sym key) {
public new Mal.Val? get(Mal.Sym key) {
if (key in data)
return this;
return data[key];
if (outer == null)
return null;
return outer.find(key);
}

public new Mal.Val get(Mal.Sym key) throws Mal.Error {
var found = find(key);
if (found == null)
throw new Error.ENV_LOOKUP_FAILED("'%s' not found", key.v);
return found.data[key];
}
}
30 changes: 11 additions & 19 deletions impls/vala/step2_eval.vala
Original file line number Diff line number Diff line change
Expand Up @@ -88,18 +88,15 @@ class Mal.Main : GLib.Object {
}
}

public static Mal.Val eval_ast(Mal.Val ast, Mal.Env env)
public static Mal.Val EVAL(Mal.Val ast, Mal.Env env)
throws Mal.Error {
var roota = new GC.Root(ast); (void)roota;
var ast_root = new GC.Root(ast); (void)ast_root;
GC.Core.maybe_collect();

// stdout.printf("EVAL: %s\n", pr_str(ast));

if (ast is Mal.Sym)
return env.get(ast as Mal.Sym);
if (ast is Mal.List) {
var result = new Mal.List.empty();
var root = new GC.Root(result); (void)root;
foreach (var elt in (ast as Mal.List).vs)
result.vs.append(EVAL(elt, env));
return result;
}
if (ast is Mal.Vector) {
var vec = ast as Mal.Vector;
var result = new Mal.Vector.with_size(vec.length);
Expand All @@ -116,25 +113,20 @@ class Mal.Main : GLib.Object {
result.insert(key, EVAL(map[key], env));
return result;
}
return ast;
}

public static Mal.Val EVAL(Mal.Val ast, Mal.Env env)
throws Mal.Error {
var ast_root = new GC.Root(ast); (void)ast_root;
GC.Core.maybe_collect();

if (ast is Mal.List) {
unowned GLib.List<Mal.Val> list = (ast as Mal.List).vs;
if (list.first() == null)
return ast;
var newlist = eval_ast(ast, env) as Mal.List;
var newlist = new Mal.List.empty();
var root = new GC.Root(newlist); (void)root;
for (var x in list)
newlist.vs.append(EVAL(x, env));
unowned GLib.List<Mal.Val> firstlink = newlist.vs.first();
var fn = firstlink.data as Mal.BuiltinFunction;
newlist.vs.remove_link(firstlink);
return fn.call(newlist);
} else {
return eval_ast(ast, env);
return ast;
}
}

Expand Down
65 changes: 31 additions & 34 deletions impls/vala/step3_env.vala
Original file line number Diff line number Diff line change
Expand Up @@ -69,38 +69,6 @@ class Mal.Main : GLib.Object {
}
}

public static Mal.Val eval_ast(Mal.Val ast, Mal.Env env)
throws Mal.Error {
var roota = new GC.Root(ast); (void)roota;
var roote = new GC.Root(env); (void)roote;
if (ast is Mal.Sym)
return env.get(ast as Mal.Sym);
if (ast is Mal.List) {
var result = new Mal.List.empty();
var root = new GC.Root(result); (void)root;
foreach (var elt in (ast as Mal.List).vs)
result.vs.append(EVAL(elt, env));
return result;
}
if (ast is Mal.Vector) {
var vec = ast as Mal.Vector;
var result = new Mal.Vector.with_size(vec.length);
var root = new GC.Root(result); (void)root;
for (var i = 0; i < vec.length; i++)
result[i] = EVAL(vec[i], env);
return result;
}
if (ast is Mal.Hashmap) {
var result = new Mal.Hashmap();
var root = new GC.Root(result); (void)root;
var map = (ast as Mal.Hashmap).vs;
foreach (var key in map.get_keys())
result.insert(key, EVAL(map[key], env));
return result;
}
return ast;
}

private static Mal.Val define_eval(Mal.Val key, Mal.Val value,
Mal.Env env)
throws Mal.Error {
Expand All @@ -121,6 +89,32 @@ class Mal.Main : GLib.Object {
var env_root = new GC.Root(env); (void)env_root;
GC.Core.maybe_collect();

var dbgeval = env.get(Mal.Sym("DEBUG-EVAL"));
if (dbgeval != null && dbgeval.truth_value())
stdout.printf("EVAL: %s\n", pr_str(ast));

if (ast is Mal.Sym)
var key = ast as Mal.Sym;
var val = env.get(key);
if (val == null)
throw new Error.ENV_LOOKUP_FAILED("'%s' not found", key.v);
return val;
if (ast is Mal.Vector) {
var vec = ast as Mal.Vector;
var result = new Mal.Vector.with_size(vec.length);
var root = new GC.Root(result); (void)root;
for (var i = 0; i < vec.length; i++)
result[i] = EVAL(vec[i], env);
return result;
}
if (ast is Mal.Hashmap) {
var result = new Mal.Hashmap();
var root = new GC.Root(result); (void)root;
var map = (ast as Mal.Hashmap).vs;
foreach (var key in map.get_keys())
result.insert(key, EVAL(map[key], env));
return result;
}
if (ast is Mal.List) {
unowned GLib.List<Mal.Val> list = (ast as Mal.List).vs;
if (list.first() == null)
Expand Down Expand Up @@ -169,7 +163,10 @@ class Mal.Main : GLib.Object {
}
}

var newlist = eval_ast(ast, env) as Mal.List;
var newlist = new Mal.List.empty();
var root = new GC.Root(newlist); (void)root;
for (var x in list)
newlist.vs.append(EVAL(x, env));
unowned GLib.List<Mal.Val> firstlink = newlist.vs.first();
Mal.Val firstdata = firstlink.data;
newlist.vs.remove_link(firstlink);
Expand All @@ -181,7 +178,7 @@ class Mal.Main : GLib.Object {
"bad value at start of list");
}
} else {
return eval_ast(ast, env);
return ast;
}
}

Expand Down
65 changes: 31 additions & 34 deletions impls/vala/step4_if_fn_do.vala
Original file line number Diff line number Diff line change
Expand Up @@ -24,38 +24,6 @@ class Mal.Main: GLib.Object {
}
}

public static Mal.Val eval_ast(Mal.Val ast, Mal.Env env)
throws Mal.Error {
var roota = new GC.Root(ast); (void)roota;
var roote = new GC.Root(env); (void)roote;
if (ast is Mal.Sym)
return env.get(ast as Mal.Sym);
if (ast is Mal.List) {
var result = new Mal.List.empty();
var root = new GC.Root(result); (void)root;
foreach (var elt in (ast as Mal.List).vs)
result.vs.append(EVAL(elt, env));
return result;
}
if (ast is Mal.Vector) {
var vec = ast as Mal.Vector;
var result = new Mal.Vector.with_size(vec.length);
var root = new GC.Root(result); (void)root;
for (var i = 0; i < vec.length; i++)
result[i] = EVAL(vec[i], env);
return result;
}
if (ast is Mal.Hashmap) {
var result = new Mal.Hashmap();
var root = new GC.Root(result); (void)root;
var map = (ast as Mal.Hashmap).vs;
foreach (var key in map.get_keys())
result.insert(key, EVAL(map[key], env));
return result;
}
return ast;
}

private static Mal.Val define_eval(Mal.Val key, Mal.Val value,
Mal.Env env)
throws Mal.Error {
Expand All @@ -76,6 +44,32 @@ class Mal.Main: GLib.Object {
var env_root = new GC.Root(env); (void)env_root;
GC.Core.maybe_collect();

var dbgeval = env.get(Mal.Sym("DEBUG-EVAL"));
if (dbgeval != null && dbgeval.truth_value())
stdout.printf("EVAL: %s\n", pr_str(ast));

if (ast is Mal.Sym)
var key = ast as Mal.Sym;
var val = env.get(key);
if (val == null)
throw new Error.ENV_LOOKUP_FAILED("'%s' not found", key.v);
return val;
if (ast is Mal.Vector) {
var vec = ast as Mal.Vector;
var result = new Mal.Vector.with_size(vec.length);
var root = new GC.Root(result); (void)root;
for (var i = 0; i < vec.length; i++)
result[i] = EVAL(vec[i], env);
return result;
}
if (ast is Mal.Hashmap) {
var result = new Mal.Hashmap();
var root = new GC.Root(result); (void)root;
var map = (ast as Mal.Hashmap).vs;
foreach (var key in map.get_keys())
result.insert(key, EVAL(map[key], env));
return result;
}
if (ast is Mal.List) {
unowned GLib.List<Mal.Val> list = (ast as Mal.List).vs;
if (list.first() == null)
Expand Down Expand Up @@ -161,7 +155,10 @@ class Mal.Main: GLib.Object {
}
}

var newlist = eval_ast(ast, env) as Mal.List;
var newlist = new Mal.List.empty();
var root = new GC.Root(newlist); (void)root;
for (var x in list)
newlist.vs.append(EVAL(x, env));
unowned GLib.List<Mal.Val> firstlink = newlist.vs.first();
Mal.Val firstdata = firstlink.data;
newlist.vs.remove_link(firstlink);
Expand All @@ -178,7 +175,7 @@ class Mal.Main: GLib.Object {
"bad value at start of list");
}
} else {
return eval_ast(ast, env);
return ast;
}
}

Expand Down
66 changes: 32 additions & 34 deletions impls/vala/step5_tco.vala
Original file line number Diff line number Diff line change
Expand Up @@ -24,38 +24,6 @@ class Mal.Main : GLib.Object {
}
}

public static Mal.Val eval_ast(Mal.Val ast, Mal.Env env)
throws Mal.Error {
var roota = new GC.Root(ast); (void)roota;
var roote = new GC.Root(env); (void)roote;
if (ast is Mal.Sym)
return env.get(ast as Mal.Sym);
if (ast is Mal.List) {
var result = new Mal.List.empty();
var root = new GC.Root(result); (void)root;
foreach (var elt in (ast as Mal.List).vs)
result.vs.append(EVAL(elt, env));
return result;
}
if (ast is Mal.Vector) {
var vec = ast as Mal.Vector;
var result = new Mal.Vector.with_size(vec.length);
var root = new GC.Root(result); (void)root;
for (var i = 0; i < vec.length; i++)
result[i] = EVAL(vec[i], env);
return result;
}
if (ast is Mal.Hashmap) {
var result = new Mal.Hashmap();
var root = new GC.Root(result); (void)root;
var map = (ast as Mal.Hashmap).vs;
foreach (var key in map.get_keys())
result.insert(key, EVAL(map[key], env));
return result;
}
return ast;
}

private static Mal.Val define_eval(Mal.Val key, Mal.Val value,
Mal.Env env)
throws Mal.Error {
Expand Down Expand Up @@ -85,6 +53,33 @@ class Mal.Main : GLib.Object {
ast_root.obj = ast;
env_root.obj = env;
GC.Core.maybe_collect();

var dbgeval = env.get(Mal.Sym("DEBUG-EVAL"));
if (dbgeval != null && dbgeval.truth_value())
stdout.printf("EVAL: %s\n", pr_str(ast));

if (ast is Mal.Sym)
var key = ast as Mal.Sym;
var val = env.get(key);
if (val == null)
throw new Error.ENV_LOOKUP_FAILED("'%s' not found", key.v);
return val;
if (ast is Mal.Vector) {
var vec = ast as Mal.Vector;
var result = new Mal.Vector.with_size(vec.length);
var root = new GC.Root(result); (void)root;
for (var i = 0; i < vec.length; i++)
result[i] = EVAL(vec[i], env);
return result;
}
if (ast is Mal.Hashmap) {
var result = new Mal.Hashmap();
var root = new GC.Root(result); (void)root;
var map = (ast as Mal.Hashmap).vs;
foreach (var key in map.get_keys())
result.insert(key, EVAL(map[key], env));
return result;
}
if (ast is Mal.List) {
unowned GLib.List<Mal.Val> list = (ast as Mal.List).vs;
if (list.first() == null)
Expand Down Expand Up @@ -172,7 +167,10 @@ class Mal.Main : GLib.Object {
}
}

var newlist = eval_ast(ast, env) as Mal.List;
var newlist = new Mal.List.empty();
var root = new GC.Root(newlist); (void)root;
for (var x in list)
newlist.vs.append(EVAL(x, env));
unowned GLib.List<Mal.Val> firstlink = newlist.vs.first();
Mal.Val firstdata = firstlink.data;
newlist.vs.remove_link(firstlink);
Expand All @@ -189,7 +187,7 @@ class Mal.Main : GLib.Object {
"bad value at start of list");
}
} else {
return eval_ast(ast, env);
return ast;
}
}
}
Expand Down
Loading

0 comments on commit 77e0d68

Please sign in to comment.