X-Git-Url: https://thelambdalab.xyz/gitweb/index.cgi?a=blobdiff_plain;f=src%2Fscheme.4th;h=72d2c9deb95bda37f81c99bad37bef4a2a59fee8;hb=ba5f17e7b376655b6e84794b33a2adc08dc8bf3f;hp=67b656c89e74aa0e94cd6e30fadb6fa462e6a27b;hpb=23fde15081cff22df3a870a7a8a5692b7761e0aa;p=scheme.forth.jl.git diff --git a/src/scheme.4th b/src/scheme.4th index 67b656c..72d2c9d 100644 --- a/src/scheme.4th +++ b/src/scheme.4th @@ -10,6 +10,7 @@ include float.4th include debugging.4th defer read +defer expand defer eval defer print @@ -261,7 +262,6 @@ create-symbol ok ok-symbol create-symbol if if-symbol create-symbol lambda lambda-symbol create-symbol λ λ-symbol -create-symbol begin begin-symbol create-symbol eof eof-symbol create-symbol no-match no-match-symbol @@ -1309,95 +1309,6 @@ parse-idx-stack parse-idx-sp ! : quote-body ( quote-obj -- quote-body-obj ) cdr car ; -: quasiquote? ( obj -- obj bool ) - quasiquote-symbol tagged-list? ; - -: unquote? ( obj -- obj bool ) - unquote-symbol tagged-list? ; - -: unquote-splicing? ( obj -- obj bool ) - unquote-splicing-symbol tagged-list? ; - -: eval-unquote ( env obj -- res ) - cdr ( env args ) - - nil? if - except-message: ." no arguments to unquote." recoverable-exception throw - then - - 2dup cdr - nil? false = if - except-message: ." too many arguments to unquote." recoverable-exception throw - then - - 2drop car 2swap eval -; - -( Create a new list from elements of l1 consed on to l2 ) -: join-lists ( l2 l1 -- l3 ) - nil? if 2drop exit then - - 2dup car - -2rot cdr - recurse cons -; - -defer eval-quasiquote-item -: eval-quasiquote-pair ( env obj -- res ) - 2over 2over ( env obj env obj ) - - cdr eval-quasiquote-item - - -2rot car ( cdritem env objcar ) - - unquote-splicing? if - eval-unquote ( cdritems caritem ) - - 2swap nil? if - 2drop - else - 2swap join-lists - then - else - eval-quasiquote-item ( cdritems caritem ) - 2swap cons - then - -; - -:noname ( env obj ) - nil? if - 2swap 2drop exit - then - - unquote? if - eval-unquote exit - then - - pair-type istype? if - eval-quasiquote-pair exit - then - - 2swap 2drop -; is eval-quasiquote-item - -: eval-quasiquote ( obj env -- res ) - 2swap cdr ( env args ) - - nil? if - except-message: ." no arguments to quasiquote." recoverable-exception throw - then - - 2dup cdr ( env args args-cdr ) - nil? false = if - except-message: ." too many arguments to quasiquote." recoverable-exception throw - then - - 2drop car ( env arg ) - - eval-quasiquote-item -; - : variable? ( obj -- obj bool ) symbol-type istype? ; @@ -1512,12 +1423,6 @@ hide env : lambda-body ( obj -- body ) cdr cdr ; -: begin? ( obj -- obj bool ) - begin-symbol tagged-list? ; - -: begin-actions ( obj -- actions ) - cdr ; - : eval-sequence ( explist env -- finalexp env ) ( Evaluates all bar the final expressions in an an expression list. The final expression @@ -1665,11 +1570,6 @@ hide env exit then - quasiquote? if - 2swap eval-quasiquote - exit - then - variable? if 2swap lookup-var exit @@ -1712,12 +1612,6 @@ hide env exit then - begin? if - begin-actions 2swap - eval-sequence - ['] eval goto-deferred - then - application? if 2over 2over ( env exp env exp ) @@ -1754,17 +1648,6 @@ hide env extend-env eval-sequence eval ; -defer expand - -: expand-quasiquote ; -: expand-definition ; -: expand-assignment ; -: expand-define-macro ; -: expand-if ; -: expand-lambda ; -: expand-begin ; -: expand-application ; - : expand-macro ( exp -- result ) pair-type istype? invert if exit then 2dup car symbol-type istype? invert if 2drop exit then @@ -1801,13 +1684,56 @@ defer expand cons cons cons ; -:noname ( exp -- result ) +: expand-list ( exp -- res ) + nil? if exit then + + 2dup car expand + 2swap cdr recurse + + cons ; + +: macro-definition-nameparams + cdr car ; + +: expand-define-macro ( exp -- res ) + define-macro-symbol 2swap + 2dup macro-definition-nameparams + 2swap macro-definition-body expand-list + + cons cons ; + +: expand-lambda ( exp -- res ) + lambda-symbol 2swap + 2dup lambda-parameters + 2swap lambda-body expand-list + + cons cons ; + +: expand-if ( exp -- res ) + if-symbol 2swap + + 2dup if-predicate expand + 2swap 2dup if-consequent expand + 2swap if-alternative none? if + 2drop nil + else + expand nil cons + then + + cons cons cons ; + +: expand-application ( exp -- res ) + 2dup operator expand + 2swap operands expand-list + + cons ; +:noname ( exp -- result ) expand-macro - quote? if exit then + self-evaluating? if exit then - quasiquote? if expand-quasiquote exit then + quote? if exit then definition? if expand-definition exit then @@ -1815,11 +1741,9 @@ defer expand macro-definition? if expand-define-macro exit then - if? if expand-if exit then - lambda? if expand-lambda exit then - begin? if expand-begin exit then + if? if expand-if exit then application? if expand-application exit then @@ -2063,9 +1987,8 @@ variable gc-stack-depth include scheme-primitives.4th - s" scheme-derived-forms.scm" load 2drop - -\ s" scheme-library.scm" load 2drop + s" testing-library.scm" load 2drop + \ s" scheme-library.scm" load 2drop \ }}}