1
1
mirror of https://github.com/kanaka/mal.git synced 2024-09-11 21:57:38 +03:00
mal/impls/chuck/env.ck

93 lines
1.8 KiB
Plaintext
Raw Permalink Normal View History

2016-04-30 21:12:07 +03:00
public class Env extends MalObject
{
MalObject outer; // this would ideally be Env, but isn't supported
MalObject data[0];
fun void init(MalObject env)
{
env @=> outer;
}
2016-05-12 11:01:09 +03:00
fun void init(MalObject env, string binds[], MalObject exprs[])
{
env @=> outer;
for( 0 => int i; i < binds.size(); i++ )
{
binds[i] => string bind;
if( bind == "&" )
{
MalObject.slice(exprs, i) @=> MalObject rest_binds[];
MalList.create(rest_binds) @=> data[binds[i+1]];
break;
}
else
{
exprs[i] @=> data[bind];
}
}
}
2016-04-30 21:12:07 +03:00
fun static Env create(MalObject env)
{
Env e;
e.init(env);
return e;
}
2016-05-12 11:01:09 +03:00
fun static Env create(MalObject env, string binds[], MalObject exprs[])
{
Env e;
e.init(env, binds, exprs);
return e;
}
2016-08-06 22:25:56 +03:00
fun MalObject clone()
{
Env value;
this.outer @=> value.outer;
this.data @=> value.data;
return value;
}
2016-04-30 21:12:07 +03:00
fun void set(string key, MalObject value)
{
value @=> data[key];
}
fun MalObject find(string key)
{
data[key] @=> MalObject value;
if( value != null )
{
return value;
}
else if( outer != null )
{
return (outer$Env).find(key);
}
else
{
return null;
}
}
fun MalObject get(string key)
{
find(key) @=> MalObject value;
if( value != null )
{
return value;
}
else
{
return MalError.create("'" + key + "' not found");
2016-04-30 21:12:07 +03:00
}
}
}