aboutsummaryrefslogtreecommitdiff
path: root/src/boot
diff options
context:
space:
mode:
authorGabriel Dos Reis <gdr@axiomatics.org>2015-12-24 10:22:27 -0800
committerGabriel Dos Reis <gdr@axiomatics.org>2015-12-24 10:22:27 -0800
commitbb81c833c0ff2ff8df936a0cd0182cf255729a41 (patch)
treea4dfaffc2374c62aa69e73ccd3653373485b7c8d /src/boot
parentdb9c4c7cd0c08a8b35a7d56d0279139021d8b945 (diff)
downloadopen-axiom-bb81c833c0ff2ff8df936a0cd0182cf255729a41.tar.gz
Translate apply(f,[args]) as FUNCALL(f,args)
Diffstat (limited to 'src/boot')
-rw-r--r--src/boot/ast.boot21
-rw-r--r--src/boot/strap/ast.clisp74
-rw-r--r--src/boot/strap/includer.clisp4
-rw-r--r--src/boot/strap/parser.clisp43
-rw-r--r--src/boot/strap/tokens.clisp12
-rw-r--r--src/boot/strap/translator.clisp21
-rw-r--r--src/boot/strap/utility.clisp58
-rw-r--r--src/boot/translator.boot12
-rw-r--r--src/boot/utility.boot32
9 files changed, 225 insertions, 52 deletions
diff --git a/src/boot/ast.boot b/src/boot/ast.boot
index ec3f47ce..632fdc47 100644
--- a/src/boot/ast.boot
+++ b/src/boot/ast.boot
@@ -1,6 +1,6 @@
-- Copyright (c) 1991-2002, The Numerical Algorithms Group Ltd.
-- All rights reserved.
--- Copyright (C) 2007-2014, Gabriel Dos Reis.
+-- Copyright (C) 2007-2015, Gabriel Dos Reis.
-- All rights reserved.
--
-- Redistribution and use in source and binary forms, with or without
@@ -40,7 +40,7 @@
import includer
namespace BOOTTRAN
-module ast (quote)
+module ast (quote, translateForm)
++ True means that Boot functions should be translated to use
++ hash tables to remember values. By default, functions are
@@ -1471,6 +1471,23 @@ genTypeAlias(head,body) ==
[op,:args] := head
["DEFTYPE",op,args,backquote(body,args)]
+translateForm x ==
+ x isnt [.,:.] => x
+ x.op is 'QUOTE => x
+ x.op is 'APPLY and x.args is [fun,:args] =>
+ lastItem args = 'NIL =>
+ ['FUNCALL,translateForm fun,:listMap!(butLast! args,function translateForm)]
+ args is [['LIST,:ys]] =>
+ ['FUNCALL,translateForm fun,:listMap!(ys, function translateForm)]
+ listMap!(x,function translateForm)
+ x.op is 'LET =>
+ bindings := [[var, translateForm init] for [var,init] in first x.args]
+ [x.op,bindings,translateForm second x.args]
+ x is ['L%T,var,init] => [x.op,var,translateForm init]
+ x.op in '(PROGN LOOP RETURN) =>
+ [x.op,:listMap!(x.args, function translateForm)]
+ listMap!(x,function translateForm)
+
--%
--% Native Interface Translation
--%
diff --git a/src/boot/strap/ast.clisp b/src/boot/strap/ast.clisp
index 2b71acb9..820f308e 100644
--- a/src/boot/strap/ast.clisp
+++ b/src/boot/strap/ast.clisp
@@ -5,7 +5,8 @@
(PROVIDE "ast")
-(EVAL-WHEN (:COMPILE-TOPLEVEL :LOAD-TOPLEVEL :EXECUTE) (EXPORT '|quote|))
+(EVAL-WHEN (:COMPILE-TOPLEVEL :LOAD-TOPLEVEL :EXECUTE)
+ (EXPORT '(|quote| |translateForm|)))
(DEFPARAMETER |$bfClamming| NIL)
@@ -1282,7 +1283,7 @@
((OR (NOT (CONSP |bfVar#1|))
(PROGN (SETQ |y| (CAR |bfVar#1|)) NIL))
(RETURN |bfVar#2|))
- (T (SETQ |bfVar#2| (APPLY |pred| |y| NIL))
+ (T (SETQ |bfVar#2| (FUNCALL |pred| |y|))
(COND ((NOT |bfVar#2|) (RETURN NIL)))))
(SETQ |bfVar#1| (CDR |bfVar#1|)))))))
@@ -2859,6 +2860,75 @@
(SETQ |args| (CDR |head|))
(LIST 'DEFTYPE |op| |args| (|backquote| |body| |args|)))))
+(DEFUN |translateForm| (|x|)
+ (LET* (|ISTMP#2| |bindings| |init| |var| |ys| |args| |fun| |ISTMP#1|)
+ (COND ((NOT (CONSP |x|)) |x|) ((EQ (CAR |x|) 'QUOTE) |x|)
+ ((AND (EQ (CAR |x|) 'APPLY)
+ (PROGN
+ (SETQ |ISTMP#1| (CDR |x|))
+ (AND (CONSP |ISTMP#1|)
+ (PROGN
+ (SETQ |fun| (CAR |ISTMP#1|))
+ (SETQ |args| (CDR |ISTMP#1|))
+ T))))
+ (COND
+ ((EQ (|lastItem| |args|) 'NIL)
+ (CONS 'FUNCALL
+ (CONS (|translateForm| |fun|)
+ (|listMap!| (|butLast!| |args|) #'|translateForm|))))
+ ((AND (CONSP |args|) (NULL (CDR |args|))
+ (PROGN
+ (SETQ |ISTMP#1| (CAR |args|))
+ (AND (CONSP |ISTMP#1|) (EQ (CAR |ISTMP#1|) 'LIST)
+ (PROGN (SETQ |ys| (CDR |ISTMP#1|)) T))))
+ (CONS 'FUNCALL
+ (CONS (|translateForm| |fun|)
+ (|listMap!| |ys| #'|translateForm|))))
+ (T (|listMap!| |x| #'|translateForm|))))
+ ((EQ (CAR |x|) 'LET)
+ (SETQ |bindings|
+ (LET ((|bfVar#3| NIL)
+ (|bfVar#4| NIL)
+ (|bfVar#2| (CAR (CDR |x|)))
+ (|bfVar#1| NIL))
+ (LOOP
+ (COND
+ ((OR (NOT (CONSP |bfVar#2|))
+ (PROGN (SETQ |bfVar#1| (CAR |bfVar#2|)) NIL))
+ (RETURN |bfVar#3|))
+ (T
+ (AND (CONSP |bfVar#1|)
+ (PROGN
+ (SETQ |var| (CAR |bfVar#1|))
+ (SETQ |ISTMP#1| (CDR |bfVar#1|))
+ (AND (CONSP |ISTMP#1|) (NULL (CDR |ISTMP#1|))
+ (PROGN (SETQ |init| (CAR |ISTMP#1|)) T)))
+ (COND
+ ((NULL |bfVar#3|)
+ (SETQ |bfVar#3|
+ #1=(CONS
+ (LIST |var|
+ (|translateForm| |init|))
+ NIL))
+ (SETQ |bfVar#4| |bfVar#3|))
+ (T (RPLACD |bfVar#4| #1#)
+ (SETQ |bfVar#4| (CDR |bfVar#4|)))))))
+ (SETQ |bfVar#2| (CDR |bfVar#2|)))))
+ (LIST (CAR |x|) |bindings| (|translateForm| (CADR (CDR |x|)))))
+ ((AND (CONSP |x|) (EQ (CAR |x|) 'L%T)
+ (PROGN
+ (SETQ |ISTMP#1| (CDR |x|))
+ (AND (CONSP |ISTMP#1|)
+ (PROGN
+ (SETQ |var| (CAR |ISTMP#1|))
+ (SETQ |ISTMP#2| (CDR |ISTMP#1|))
+ (AND (CONSP |ISTMP#2|) (NULL (CDR |ISTMP#2|))
+ (PROGN (SETQ |init| (CAR |ISTMP#2|)) T))))))
+ (LIST (CAR |x|) |var| (|translateForm| |init|)))
+ ((|symbolMember?| (CAR |x|) '(PROGN LOOP RETURN))
+ (CONS (CAR |x|) (|listMap!| (CDR |x|) #'|translateForm|)))
+ (T (|listMap!| |x| #'|translateForm|)))))
+
(DEFCONSTANT |$NativeSimpleDataTypes|
'(|char| |byte| |int| |pointer| |int8| |uint8| |int16| |uint16| |int32|
|uint32| |int64| |uint64| |float| |float32| |double| |float64|))
diff --git a/src/boot/strap/includer.clisp b/src/boot/strap/includer.clisp
index e2cf37f2..bd556ea1 100644
--- a/src/boot/strap/includer.clisp
+++ b/src/boot/strap/includer.clisp
@@ -83,7 +83,7 @@
(DEFUN |bMap1| (|f| |x|)
(COND ((|bStreamNull| |x|) |$bStreamNil|)
- (T (CONS (APPLY |f| (LIST (CAR |x|))) (|bMap| |f| (CDR |x|))))))
+ (T (CONS (FUNCALL |f| (CAR |x|)) (|bMap| |f| (CDR |x|))))))
(DEFUN |bDelay| (|f| |x|) (CONS '|nonnullstream| (CONS |f| |x|)))
@@ -100,7 +100,7 @@
(DEFUN |bNext1| (|f| |s|)
(LET* (|h|)
(COND ((|bStreamNull| |s|) (LIST '|nullstream|))
- (T (SETQ |h| (APPLY |f| (LIST |s|)))
+ (T (SETQ |h| (FUNCALL |f| |s|))
(|bAppend| (CAR |h|) (|bNext| |f| (CDR |h|)))))))
(DEFUN |bRgen| (|s|) (|bDelay| #'|bRgen1| (LIST |s|)))
diff --git a/src/boot/strap/parser.clisp b/src/boot/strap/parser.clisp
index 7684716b..50a1b076 100644
--- a/src/boot/strap/parser.clisp
+++ b/src/boot/strap/parser.clisp
@@ -84,7 +84,7 @@
(SETF (|parserTokens| |ps|) (CDR (|parserTokens| |ps|)))
(|bpFirstToken| |ps|)))
-(DEFUN |bpRequire| (|ps| |f|) (OR (APPLY |f| |ps| NIL) (|bpTrap| |ps|)))
+(DEFUN |bpRequire| (|ps| |f|) (OR (FUNCALL |f| |ps|) (|bpTrap| |ps|)))
(DEFUN |bpState| (|ps|)
(LIST (|parserTokens| |ps|) (|parserTrees| |ps|) (|parserNesting| |ps|)
@@ -140,7 +140,7 @@
(SETF (|parserNesting| |ps|) (+ (|parserNesting| |ps|) 1))
(|bpNext| |ps|)
(COND
- ((AND (APPLY |f| |ps| NIL) (|bpFirstTok| |ps|)
+ ((AND (FUNCALL |f| |ps|) (|bpFirstTok| |ps|)
(OR (|bpEqPeek| |ps| 'CPAREN) (|bpParenTrap| |ps| |a|)))
(SETF (|parserNesting| |ps|) (- (|parserNesting| |ps|) 1))
(|bpNextToken| |ps|)
@@ -167,7 +167,7 @@
(COND
((|bpEqKey| |ps| 'OPAREN)
(COND
- ((AND (APPLY |f| |ps| NIL)
+ ((AND (FUNCALL |f| |ps|)
(OR (|bpEqKey| |ps| 'CPAREN) (|bpParenTrap| |ps| |a|)))
T)
((|bpEqKey| |ps| 'CPAREN) (|bpPush| |ps| (|bfTuple| NIL)) T)
@@ -181,7 +181,7 @@
(COND
((|bpEqKey| |ps| 'OBRACK)
(COND
- ((AND (APPLY |f| |ps| NIL)
+ ((AND (FUNCALL |f| |ps|)
(OR (|bpEqKey| |ps| 'CBRACK) (|bpBrackTrap| |ps| |a|)))
(|bpPush| |ps| (|bfBracket| (|bpPop1| |ps|))))
((|bpEqKey| |ps| 'CBRACK) (|bpPush| |ps| NIL))
@@ -192,7 +192,7 @@
(COND
((|bpEqKey| |ps| 'SETTAB)
(COND ((|bpEqKey| |ps| 'BACKTAB) T)
- ((AND (APPLY |f| |ps| NIL)
+ ((AND (FUNCALL |f| |ps|)
(OR (|bpEqKey| |ps| 'BACKTAB) (|bpPileTrap| |ps|)))
(|bpPush| |ps| (|bfPile| (|bpPop1| |ps|))))
(T NIL)))
@@ -201,7 +201,7 @@
(DEFUN |bpListof| (|ps| |f| |str1| |g|)
(LET* (|a|)
(COND
- ((APPLY |f| |ps| NIL)
+ ((FUNCALL |f| |ps|)
(COND
((AND (|bpEqKey| |ps| |str1|) (|bpRequire| |ps| |f|))
(SETQ |a| (|parserTrees| |ps|)) (SETF (|parserTrees| |ps|) NIL)
@@ -222,14 +222,13 @@
(DEFUN |bpListofFun| (|ps| |f| |h| |g|)
(LET* (|a|)
(COND
- ((APPLY |f| |ps| NIL)
+ ((FUNCALL |f| |ps|)
(COND
- ((AND (APPLY |h| |ps| NIL) (|bpRequire| |ps| |f|))
+ ((AND (FUNCALL |h| |ps|) (|bpRequire| |ps| |f|))
(SETQ |a| (|parserTrees| |ps|)) (SETF (|parserTrees| |ps|) NIL)
(LOOP
(COND
- ((NOT (AND (APPLY |h| |ps| NIL) (|bpRequire| |ps| |f|)))
- (RETURN NIL))
+ ((NOT (AND (FUNCALL |h| |ps|) (|bpRequire| |ps| |f|))) (RETURN NIL))
(T NIL)))
(SETF (|parserTrees| |ps|)
(CONS (|reverse!| (|parserTrees| |ps|)) |a|))
@@ -243,7 +242,7 @@
(DEFUN |bpList| (|ps| |f| |str1|)
(LET* (|a|)
(COND
- ((APPLY |f| |ps| NIL)
+ ((FUNCALL |f| |ps|)
(COND
((AND (|bpEqKey| |ps| |str1|) (|bpRequire| |ps| |f|))
(SETQ |a| (|parserTrees| |ps|)) (SETF (|parserTrees| |ps|) NIL)
@@ -263,15 +262,15 @@
(DEFUN |bpOneOrMore| (|ps| |f|)
(LET* (|a|)
(COND
- ((APPLY |f| |ps| NIL) (SETQ |a| (|parserTrees| |ps|))
+ ((FUNCALL |f| |ps|) (SETQ |a| (|parserTrees| |ps|))
(SETF (|parserTrees| |ps|) NIL)
- (LOOP (COND ((NOT (APPLY |f| |ps| NIL)) (RETURN NIL)) (T NIL)))
+ (LOOP (COND ((NOT (FUNCALL |f| |ps|)) (RETURN NIL)) (T NIL)))
(SETF (|parserTrees| |ps|) (CONS (|reverse!| (|parserTrees| |ps|)) |a|))
(|bpPush| |ps| (CONS (|bpPop2| |ps|) (|bpPop1| |ps|))))
(T NIL))))
(DEFUN |bpAnyNo| (|ps| |s|)
- (PROGN (LOOP (COND ((NOT (APPLY |s| |ps| NIL)) (RETURN NIL)) (T NIL))) T))
+ (PROGN (LOOP (COND ((NOT (FUNCALL |s| |ps|)) (RETURN NIL)) (T NIL))) T))
(DEFUN |bpAndOr| (|ps| |keyword| |p| |f|)
(AND (|bpEqKey| |ps| |keyword|) (|bpRequire| |ps| |p|)
@@ -388,9 +387,8 @@
(COND (|done| (RETURN NIL))
(T
(SETQ |found|
- (LET ((#1=#:G727
- (CATCH :OPEN-AXIOM-CATCH-POINT
- (APPLY |f| |ps| NIL))))
+ (LET ((#1=#:G392
+ (CATCH :OPEN-AXIOM-CATCH-POINT (FUNCALL |f| |ps|))))
(COND
((AND (CONSP #1#)
(EQUAL (CAR #1#) :OPEN-AXIOM-CATCH-POINT))
@@ -730,7 +728,7 @@
(PROGN
(SETQ |a| (|bpState| |ps|))
(COND
- ((APPLY |p| |ps| NIL)
+ ((FUNCALL |p| |ps|)
(LOOP
(COND
((NOT
@@ -746,7 +744,7 @@
(DEFUN |bpLeftAssoc| (|ps| |operations| |parser|)
(COND
- ((APPLY |parser| |ps| NIL)
+ ((FUNCALL |parser| |ps|)
(LOOP
(COND
((NOT
@@ -1057,9 +1055,8 @@
(DEFUN |bpCompoundDefinitionTail| (|ps| |f|)
(AND (|bpVariable| |ps|) (|bpEqKey| |ps| 'DEF) (|bpRequire| |ps| #'|bpWhere|)
(|bpPush| |ps|
- (APPLY |f|
- (LIST (|bpPop3| |ps|) (|bpPop2| |ps|)
- (|bpPop1| |ps|))))))
+ (FUNCALL |f| (|bpPop3| |ps|) (|bpPop2| |ps|)
+ (|bpPop1| |ps|)))))
(DEFUN |bpDefTail| (|ps| |f|)
(OR (|bpSimpleDefinitionTail| |ps|) (|bpCompoundDefinitionTail| |ps| |f|)))
@@ -1378,7 +1375,7 @@
(SETQ |op| (|enclosingFunction| (|parserLoadUnit| |ps|)))
(SETQ |varno| (|parserGensymSequenceNumber| |ps|))
(UNWIND-PROTECT
- (LET ((#1=#:G728
+ (LET ((#1=#:G393
(CATCH :OPEN-AXIOM-CATCH-POINT
(PROGN
(SETF (|enclosingFunction| (|parserLoadUnit| |ps|)) NIL)
diff --git a/src/boot/strap/tokens.clisp b/src/boot/strap/tokens.clisp
index 6fa7d340..9f975637 100644
--- a/src/boot/strap/tokens.clisp
+++ b/src/boot/strap/tokens.clisp
@@ -84,10 +84,10 @@
(LET* (|s|)
(COND
((SETQ |s|
- (WITH-HASH-TABLE-ITERATOR (#1=#:G726 |shoeKeyTable|)
+ (WITH-HASH-TABLE-ITERATOR (#1=#:G391 |shoeKeyTable|)
(LET ((|bfVar#1| NIL))
(LOOP
- (MULTIPLE-VALUE-BIND (#2=#:G727 |k| |v|)
+ (MULTIPLE-VALUE-BIND (#2=#:G392 |k| |v|)
(#1#)
(COND ((NOT #2#) (RETURN |bfVar#1|))
(T
@@ -138,9 +138,9 @@
(COND ((> |i| 255) (RETURN NIL)) (T (SETF (ELT |a| |i|) |b|)))
(SETQ |i| (+ |i| 1))))
|a|))
- (WITH-HASH-TABLE-ITERATOR (#1=#:G728 |shoeKeyTable|)
+ (WITH-HASH-TABLE-ITERATOR (#1=#:G393 |shoeKeyTable|)
(LOOP
- (MULTIPLE-VALUE-BIND (#2=#:G729 |s| #:G730)
+ (MULTIPLE-VALUE-BIND (#2=#:G394 |s| #:G395)
(#1#)
(COND ((NOT #2#) (RETURN NIL)) (T (|shoeInsert| |s| |d|))))))
|d|)))
@@ -154,9 +154,9 @@
(LET ((|i| 0))
(LOOP (COND ((> |i| 255) (RETURN NIL)) (T (SETF (SBIT |a| |i|) 0)))
(SETQ |i| (+ |i| 1))))
- (WITH-HASH-TABLE-ITERATOR (#1=#:G731 |shoeKeyTable|)
+ (WITH-HASH-TABLE-ITERATOR (#1=#:G396 |shoeKeyTable|)
(LOOP
- (MULTIPLE-VALUE-BIND (#2=#:G732 |k| #:G733)
+ (MULTIPLE-VALUE-BIND (#2=#:G397 |k| #:G398)
(#1#)
(COND ((NOT #2#) (RETURN NIL)) ((|shoeStartsId| (SCHAR |k| 0)) NIL)
(T (SETF (SBIT |a| (CHAR-CODE (SCHAR |k| 0))) 1))))))
diff --git a/src/boot/strap/translator.clisp b/src/boot/strap/translator.clisp
index 99d7f82a..8e7ab21c 100644
--- a/src/boot/strap/translator.clisp
+++ b/src/boot/strap/translator.clisp
@@ -16,7 +16,7 @@
(EVAL-WHEN (:COMPILE-TOPLEVEL :LOAD-TOPLEVEL :EXECUTE)
(EXPORT
'(|evalBootFile| |loadNativeModule| |loadSystemRuntimeCore|
- |string2BootTree| |genImportDeclaration|)))
+ |string2BootTree| |genImportDeclaration| |retainFile?|)))
(DEFPARAMETER |$currentModuleName| NIL)
@@ -416,7 +416,7 @@
(SETQ |ps| (|makeParserState| |toks|))
(|bpFirstTok| |ps|)
(SETQ |found|
- (LET ((#1=#:G736
+ (LET ((#1=#:G401
(CATCH :OPEN-AXIOM-CATCH-POINT (|bpOutItem| |ps|))))
(COND
((AND (CONSP #1#) (EQUAL (CAR #1#) :OPEN-AXIOM-CATCH-POINT))
@@ -585,7 +585,9 @@
(LET ((|op| (CADR |b|))
(|args| (CADDR |b|))
(|body| (CADDDR |b|)))
- (CDR (|bfDef| (|parserLoadUnit| |ps|) |op| |args| |body|))))
+ (CDR
+ (|bfDef| (|parserLoadUnit| |ps|) |op| |args|
+ (|translateForm| |body|)))))
(|%Module|
(LET ((|m| (CADR |b|)) (|ns| (CADDR |b|)) (|ds| (CADDDR |b|)))
(PROGN
@@ -659,7 +661,7 @@
(SETQ |sig| (|genDeclaration| |n| |t|)) (SETQ |lhs| |n|)))
(SETQ |$constantIdentifiers|
(CONS |lhs| |$constantIdentifiers|))
- (LIST (LIST 'DEFCONSTANT |lhs| |rhs|))))))
+ (LIST (LIST 'DEFCONSTANT |lhs| (|translateForm| |rhs|)))))))
(|%Assignment|
(LET ((|lhs| (CADR |b|)) (|rhs| (CADDR |b|)))
(PROGN
@@ -676,12 +678,16 @@
(PROGN (SETQ |t| (CAR |ISTMP#2|)) T))))))
(SETQ |sig| (|genDeclaration| |n| |t|)) (SETQ |lhs| |n|)))
(COND (|$InteractiveMode| (LIST (LIST 'SETF |lhs| |rhs|)))
- (T (LIST (LIST 'DEFPARAMETER |lhs| |rhs|)))))))
+ (T
+ (LIST
+ (LIST 'DEFPARAMETER |lhs|
+ (|translateForm| |rhs|))))))))
(|%Macro|
(LET ((|op| (CADR |b|))
(|args| (CADDR |b|))
(|body| (CADDDR |b|)))
- (|bfMDef| (|parserLoadUnit| |ps|) |op| |args| |body|)))
+ (|bfMDef| (|parserLoadUnit| |ps|) |op| |args|
+ (|translateForm| |body|))))
(|%Structure|
(LET ((|t| (CADR |b|)) (|alts| (CADDR |b|)))
(COND
@@ -733,7 +739,8 @@
(|%Lisp|
(LET ((|s| (CADR |b|)))
(|shoeReadLispString| |s| 0)))
- (T (LIST (|translateToplevelExpression| |b|))))))))
+ (T
+ (LIST (|translateToplevelExpression| (|translateForm| |b|)))))))))
(DEFUN |shoeAddbootIfNec| (|s|)
(LET* (|n2| |n1| |ext|)
diff --git a/src/boot/strap/utility.clisp b/src/boot/strap/utility.clisp
index 1a288c10..784ec366 100644
--- a/src/boot/strap/utility.clisp
+++ b/src/boot/strap/utility.clisp
@@ -18,7 +18,8 @@
'(|objectMember?| |symbolMember?| |stringMember?| |charMember?|
|scalarMember?| |listMember?| |reverse| |reverse!|
|lastNode| |append| |append!| |copyList| |substitute|
- |substitute!| |setDifference| |setUnion| |setIntersection|
+ |substitute!| |listMap| |listMap!| |butLast| |butLast!|
+ |lastItem| |setDifference| |setUnion| |setIntersection|
|symbolAssoc| |applySubst| |applySubst!| |applySubstNQ|
|objectAssoc| |invertSubst| |substTarget| |substSource|
|remove| |removeSymbol| |atomic?| |every?| |any?| |take|
@@ -43,6 +44,12 @@
(FTYPE (FUNCTION ((|%List| |%Thing|)) (|%Maybe| (|%Node| |%Thing|)))
|lastNode|))
+(DECLAIM (FTYPE (FUNCTION ((|%List| |%Thing|)) |%Thing|) |lastItem|))
+
+(DECLAIM (FTYPE (FUNCTION ((|%List| |%Thing|)) (|%List| |%Thing|)) |butLast|))
+
+(DECLAIM (FTYPE (FUNCTION ((|%List| |%Thing|)) (|%List| |%Thing|)) |butLast!|))
+
(DECLAIM
(FTYPE (FUNCTION ((|%List| |%Thing|) |%Symbol|) (|%List| |%Thing|))
|removeSymbol|))
@@ -120,7 +127,7 @@
(COND
((OR (NOT (CONSP |bfVar#1|)) (PROGN (SETQ |x| (CAR |bfVar#1|)) NIL))
(RETURN |bfVar#2|))
- (T (SETQ |bfVar#2| (APPLY |f| |x| NIL))
+ (T (SETQ |bfVar#2| (FUNCALL |f| |x|))
(COND ((NOT |bfVar#2|) (RETURN NIL)))))
(SETQ |bfVar#1| (CDR |bfVar#1|)))))
@@ -130,7 +137,7 @@
(COND
((OR (NOT (CONSP |bfVar#1|)) (PROGN (SETQ |x| (CAR |bfVar#1|)) NIL))
(RETURN |bfVar#2|))
- (T (SETQ |bfVar#2| (APPLY |f| |x| NIL))
+ (T (SETQ |bfVar#2| (FUNCALL |f| |x|))
(COND (|bfVar#2| (RETURN |bfVar#2|)))))
(SETQ |bfVar#1| (CDR |bfVar#1|)))))
@@ -159,7 +166,7 @@
(LOOP
(COND
((OR (NOT (CONSP |bfVar#1|)) (PROGN (SETQ |x| (CAR |bfVar#1|)) NIL)
- (NOT (APPLY |f| |x| NIL)))
+ (NOT (FUNCALL |f| |x|)))
(RETURN |bfVar#2|))
((NULL |bfVar#2|) (SETQ |bfVar#2| #1=(CONS |x| NIL))
(SETQ |bfVar#3| |bfVar#2|))
@@ -254,6 +261,29 @@
(T (SETQ |l| |l'|))))
|l|)))
+(DEFUN |lastItem| (|l|) (CAR (|lastNode| |l|)))
+
+(DEFUN |butLast| (|l|)
+ (LET* (|xs| |LETTMP#1|)
+ (COND ((NOT (CONSP |l|)) NIL)
+ (T (SETQ |LETTMP#1| (|reverse| |l|))
+ (SETQ |xs| (|reverse!| (CDR |LETTMP#1|))) |xs|))))
+
+(DEFUN |butLast!| (|l|)
+ (LET* (|ISTMP#1|)
+ (COND ((OR (NOT (CONSP |l|)) (NULL (CDR |l|))) NIL)
+ (T
+ (LET ((|xs| |l|))
+ (LOOP
+ (COND ((NOT (CONSP |xs|)) (RETURN NIL))
+ ((AND (CONSP |xs|)
+ (PROGN
+ (SETQ |ISTMP#1| (CDR |xs|))
+ (AND (CONSP |ISTMP#1|) (NULL (CDR |ISTMP#1|)))))
+ (IDENTITY (RETURN (RPLACD |xs| NIL)))))
+ (SETQ |xs| (CDR |xs|))))
+ |l|))))
+
(DEFUN |copyList| (|l|)
(LET* (|l'| |t|)
(COND ((NOT (CONSP |l|)) |l|)
@@ -271,6 +301,26 @@
(DEFUN |append| (|x| |y|) (|append!| (|copyList| |x|) |y|))
+(DEFUN |listMap| (|l| |fun|)
+ (LET ((|bfVar#2| NIL) (|bfVar#3| NIL) (|bfVar#1| |l|) (|x| NIL))
+ (LOOP
+ (COND
+ ((OR (NOT (CONSP |bfVar#1|)) (PROGN (SETQ |x| (CAR |bfVar#1|)) NIL))
+ (RETURN |bfVar#2|))
+ ((NULL |bfVar#2|) (SETQ |bfVar#2| #1=(CONS (FUNCALL |fun| |x|) NIL))
+ (SETQ |bfVar#3| |bfVar#2|))
+ (T (RPLACD |bfVar#3| #1#) (SETQ |bfVar#3| (CDR |bfVar#3|))))
+ (SETQ |bfVar#1| (CDR |bfVar#1|)))))
+
+(DEFUN |listMap!| (|l| |fun|)
+ (PROGN
+ (LET ((|xs| |l|))
+ (LOOP
+ (COND ((NOT (CONSP |xs|)) (RETURN NIL))
+ (T (RPLACA |xs| (FUNCALL |fun| (CAR |xs|)))))
+ (SETQ |xs| (CDR |xs|))))
+ |l|))
+
(DEFUN |symbolAssoc| (|s| |l|)
(LET* (|x|)
(LOOP
diff --git a/src/boot/translator.boot b/src/boot/translator.boot
index 8ba8e4fc..17aab40c 100644
--- a/src/boot/translator.boot
+++ b/src/boot/translator.boot
@@ -433,7 +433,8 @@ translateToplevel(ps,b,export?) ==
b is ["TUPLE",:xs] => coreError '"invalid AST"
case b of
%Signature(op,t) => [genDeclaration(op,t)]
- %Definition(op,args,body) => bfDef(parserLoadUnit ps,op,args,body).args
+ %Definition(op,args,body) =>
+ bfDef(parserLoadUnit ps,op,args,translateForm body).args
%Module(m,ns,ds) =>
$currentModuleName := m
@@ -460,7 +461,7 @@ translateToplevel(ps,b,export?) ==
sig := genDeclaration(n,t)
lhs := n
$constantIdentifiers := [lhs,:$constantIdentifiers]
- [["DEFCONSTANT",lhs,rhs]]
+ [["DEFCONSTANT",lhs,translateForm rhs]]
%Assignment(lhs,rhs) =>
sig := nil
@@ -468,9 +469,10 @@ translateToplevel(ps,b,export?) ==
sig := genDeclaration(n,t)
lhs := n
$InteractiveMode => [["SETF",lhs,rhs]]
- [["DEFPARAMETER",lhs,rhs]]
+ [["DEFPARAMETER",lhs,translateForm rhs]]
- %Macro(op,args,body) => bfMDef(parserLoadUnit ps,op,args,body)
+ %Macro(op,args,body) =>
+ bfMDef(parserLoadUnit ps,op,args,translateForm body)
%Structure(t,alts) =>
alts is ['%Record,fields,accessors] =>
@@ -485,7 +487,7 @@ translateToplevel(ps,b,export?) ==
%Lisp s => shoeReadLispString(s,0)
otherwise =>
- [translateToplevelExpression b]
+ [translateToplevelExpression translateForm b]
shoeAddbootIfNec s ==
ext := '".boot"
diff --git a/src/boot/utility.boot b/src/boot/utility.boot
index 86607f20..37907145 100644
--- a/src/boot/utility.boot
+++ b/src/boot/utility.boot
@@ -1,4 +1,4 @@
--- Copyright (C) 2012-2014, Gabriel Dos Reis.
+-- Copyright (C) 2012-2015, Gabriel Dos Reis.
-- All rights reserved.
--
-- Redistribution and use in source and binary forms, with or without
@@ -46,6 +46,7 @@ namespace BOOTTRAN
module utility (objectMember?, symbolMember?, stringMember?,
charMember?, scalarMember?, listMember?, reverse, reverse!,
lastNode, append, append!, copyList, substitute, substitute!,
+ listMap, listMap!, butLast, butLast!, lastItem,
setDifference, setUnion, setIntersection,
symbolAssoc, applySubst, applySubst!, applySubstNQ, objectAssoc,
invertSubst, substTarget, substSource,
@@ -58,6 +59,9 @@ module utility (objectMember?, symbolMember?, stringMember?,
append!: (%List %Thing,%List %Thing) -> %List %Thing
copyList: %List %Thing -> %List %Thing
lastNode: %List %Thing -> %Maybe %Node %Thing
+ lastItem: %List %Thing -> %Thing
+ butLast: %List %Thing -> %List %Thing
+ butLast!: %List %Thing -> %List %Thing
removeSymbol: (%List %Thing, %Symbol) -> %List %Thing
remove: (%List %Thing, %Thing) -> %List %Thing
objectAssoc: (%Thing, %List %Thing) -> %Maybe %Pair(%Thing,%Thing)
@@ -195,6 +199,22 @@ lastNode l ==
l := l'
l
+--% return the content of the last item in the list `l'.
+lastItem l ==
+ first lastNode l
+
+--% return a copy of the input list except the last cons-cell.
+butLast l ==
+ l isnt [.,:.] => nil
+ [:xs,.] := l
+ xs
+
+butLast! l ==
+ l isnt [.,:.] or rest l = nil => nil
+ for xs in tails l repeat
+ xs is [.,.] => return xs.rest := nil
+ l
+
--% list copying
copyList l ==
l isnt [.,:.] => l
@@ -218,6 +238,16 @@ append!(x,y) ==
append(x,y) ==
append!(copyList x,y)
+--% listMap
+listMap(l,fun) ==
+ [apply(fun,[x]) for x in l]
+
+--% lispMap!
+listMap!(l,fun) ==
+ for xs in tails l repeat
+ xs.first := apply(fun,[first xs])
+ l
+
--% a-list
symbolAssoc(s,l) ==