1
1
mirror of https://github.com/kanaka/mal.git synced 2024-10-27 14:52:16 +03:00
mal/impls/julia/env.jl

56 lines
877 B
Julia
Raw Normal View History

2015-03-29 23:00:27 +03:00
module env
export Env, env_set, env_find, env_get
2015-03-29 23:00:27 +03:00
type Env
outer::Any
data::Dict{Symbol,Any}
end
function Env()
Env(nothing, Dict())
end
function Env(outer)
Env(outer, Dict())
end
2015-03-29 23:38:05 +03:00
function Env(outer, binds, exprs)
e = Env(outer, Dict())
for i=1:length(binds)
if binds[i] == :&
e.data[binds[i+1]] = exprs[i:end]
break
else
e.data[binds[i]] = exprs[i]
end
end
e
end
function env_set(env::Env, k::Symbol, v)
2015-03-29 23:00:27 +03:00
env.data[k] = v
end
function env_find(env::Env, k::Symbol)
2015-03-29 23:00:27 +03:00
if haskey(env.data, k)
env
elseif env.outer != nothing
env_find(env.outer, k)
2015-03-29 23:00:27 +03:00
else
nothing
end
end
function env_get(env::Env, k::Symbol)
e = env_find(env, k)
2015-03-29 23:00:27 +03:00
if e != nothing
e.data[k]
else
error("'$(string(k))' not found")
end
end
end