diff options
Diffstat (limited to 'src/interp')
-rw-r--r-- | src/interp/g-util.boot | 15 | ||||
-rw-r--r-- | src/interp/i-spec2.boot | 5 |
2 files changed, 18 insertions, 2 deletions
diff --git a/src/interp/g-util.boot b/src/interp/g-util.boot index 4c3c9801..d70a7361 100644 --- a/src/interp/g-util.boot +++ b/src/interp/g-util.boot @@ -36,6 +36,9 @@ import macros import sys_-utility namespace BOOT +module g_-util where + getTypeOfSyntax: %Form -> %Mode + ++ $interpOnly := false @@ -105,6 +108,8 @@ put(x,prop,val,e) == addBinding(x,newProplist,e) +--% Syntax manipulation + ++ Build a quasiquotation form for `x'. quasiquote x == ["[||]",x] @@ -114,6 +119,16 @@ isQuasiquote m == m is ["[||]",y] => y +getTypeOfSyntax t == + atom t => + IDENTP t => '(Identifier) + (m := getBasicMode t) and not member(m,[$EmptyMode,$NoValueMode]) => + ["Literal",m] + $Syntax + $Syntax + +--% + -- Convert an arbitrary lisp object to canonical boolean. bool: %Thing -> %Boolean bool x == diff --git a/src/interp/i-spec2.boot b/src/interp/i-spec2.boot index e78da954..f4256a06 100644 --- a/src/interp/i-spec2.boot +++ b/src/interp/i-spec2.boot @@ -809,8 +809,9 @@ evalQUOTE(op,[expr],[m]) == --% Quasiquotation up_[_|_|_] t == t isnt [op, x] => nil - putValue(op, objNewWrap(x, $Syntax)) - putModeSet(op, [$Syntax]) + mode := getTypeOfSyntax x + putValue(op, objNewWrap(x, mode)) + putModeSet(op, [mode]) --% Handler for pretend |