1
1
mirror of https://github.com/kanaka/mal.git synced 2024-11-10 02:45:44 +03:00
mal/miniMAL/env.json
2015-02-24 09:17:42 -06:00

43 lines
1.3 KiB
JSON

["do",
["def", "env-bind", ["fn", ["env", "b", "e"],
["if", ["empty?", "b"],
"env",
["if", ["=", ["`", "&"],
["get", ["first", "b"], ["`", "val"]]],
["assoc!", "env", ["get", ["nth", "b", 1], ["`", "val"]], "e"],
["env-bind", ["assoc!", "env", ["get", ["first", "b"], ["`", "val"]],
["first", "e"]],
["rest", "b"],
["rest", "e"]]]]]],
["def", "env-new", ["fn", ["&", "args"],
["let", ["env", ["hash-map", ["`", "__outer__"], ["first", "args"]]],
["if", ["<=", ["count", "args"], 1],
"env",
["env-bind", "env", ["get", "args", 1], ["get", "args", 2]]]]]],
["def", "env-find", ["fn", ["env", "key"],
["let", ["k", ["get", "key", ["`", "val"]]],
["if", ["contains?", "env", "k"],
"env",
["if", ["get", "env", ["`", "__outer__"]],
["env-find", ["get", "env", ["`", "__outer__"]], "key"],
null]]]]],
["def", "env-get", ["fn", ["env", "key"],
["let", ["k", ["get", "key", ["`", "val"]],
"e", ["env-find", "env", "key"]],
["if", "e",
["get", "e", "k"],
["throw", ["str", ["`", "'"], "k", ["`", "' not found"]]]]]]],
["def", "env-set", ["fn", ["env", "key", "val"],
["let", ["k", ["get", "key", ["`", "val"]]],
["do",
["assoc!", "env", "k", "val"],
"val"]]]],
null
]