From 0027e8fed423a24ec93234a6bf0fb701c233d583 Mon Sep 17 00:00:00 2001 From: Joel Martin Date: Mon, 14 Apr 2014 22:46:54 -0500 Subject: PS: fix function closures. Self-hosted up to step7. --- ps/step6_file.ps | 23 +++++++---------------- 1 file changed, 7 insertions(+), 16 deletions(-) (limited to 'ps/step6_file.ps') diff --git a/ps/step6_file.ps b/ps/step6_file.ps index 1eff14f..fc12cc1 100644 --- a/ps/step6_file.ps +++ b/ps/step6_file.ps @@ -90,27 +90,18 @@ end } def }{ /fn* a0 eq { %if fn* /a1 ast 1 _nth def /a2 ast 2 _nth def - << - /_maltype_ /function % user defined function - /params null % close over parameters - /ast null % close over ast - /env null % close over environment - /data { __self__ fload EVAL } - >> - dup length dict copy % make an actual copy/new instance - dup /params a1 put % insert closed over a1 into position 2 - dup /ast a2 put % insert closed over a2 into position 3 - dup /env env put % insert closed over env into position 4 - dup dup /data get exch 0 exch put % insert self reference + a2 env a1 _mal_function }{ /el ast env eval_ast def el _rest el _first % stack: ast function - dup _mal_function? { % if user defined function + dup _mal_function? { %if user defined function fload % stack: ast new_env /loop? true def + }{ dup _function? { %else if builtin function + /data get exec }{ %else (regular procedure/function) - exec % apply function to args - } ifelse + (cannot apply native proc!\n) print quit + } ifelse } ifelse } ifelse } ifelse } ifelse } ifelse } ifelse } ifelse @@ -130,7 +121,7 @@ end } def /RE { READ repl_env EVAL } def /REP { READ repl_env EVAL PRINT } def -/_ref { repl_env 3 1 roll env_set pop } def +/_ref { _function repl_env 3 1 roll env_set pop } def core_ns { _ref } forall -- cgit v1.2.3