diff options
author | dos-reis <gdr@axiomatics.org> | 2011-04-28 04:45:25 +0000 |
---|---|---|
committer | dos-reis <gdr@axiomatics.org> | 2011-04-28 04:45:25 +0000 |
commit | 9c53b933216af4ae6c7233384ace756572dcb597 (patch) | |
tree | 37fe3f4c12745a5c0d81f8fe2155708d54cfa6fc /src/boot | |
parent | 0df2bba385eeeaf650b6c13b2f4b10f991929ec8 (diff) | |
download | open-axiom-9c53b933216af4ae6c7233384ace756572dcb597.tar.gz |
* boot/ast.boot (bfReduceCollect): Delegate to bfDoCollect if
op is append or append!.
Diffstat (limited to 'src/boot')
-rw-r--r-- | src/boot/ast.boot | 2 | ||||
-rw-r--r-- | src/boot/strap/ast.clisp | 13 |
2 files changed, 12 insertions, 3 deletions
diff --git a/src/boot/ast.boot b/src/boot/ast.boot index bc444a4e..15a720bc 100644 --- a/src/boot/ast.boot +++ b/src/boot/ast.boot @@ -351,6 +351,8 @@ bfReduceCollect(op,y)== a := op is ["QUOTE",:.] => second op op + a is "append!" => bfDoCollect(body,itl,'lastNode,'skipNil) + a is "append" => bfDoCollect(['copyList,body],itl,'lastNode,'skipNil) op := bfReName a init := a has SHOETHETA or op has SHOETHETA bfOpReduce(op,init,body,itl) diff --git a/src/boot/strap/ast.clisp b/src/boot/strap/ast.clisp index c4249a0d..9597b66d 100644 --- a/src/boot/strap/ast.clisp +++ b/src/boot/strap/ast.clisp @@ -484,9 +484,16 @@ ((AND (CONSP |op|) (EQ (CAR |op|) 'QUOTE)) (CADR |op|)) (T |op|))) - (SETQ |op| (|bfReName| |a|)) - (SETQ |init| (OR (GET |a| 'SHOETHETA) (GET |op| 'SHOETHETA))) - (|bfOpReduce| |op| |init| |body| |itl|)) + (COND + ((EQ |a| '|append!|) + (|bfDoCollect| |body| |itl| '|lastNode| '|skipNil|)) + ((EQ |a| '|append|) + (|bfDoCollect| (LIST '|copyList| |body|) |itl| '|lastNode| + '|skipNil|)) + (T (SETQ |op| (|bfReName| |a|)) + (SETQ |init| + (OR (GET |a| 'SHOETHETA) (GET |op| 'SHOETHETA))) + (|bfOpReduce| |op| |init| |body| |itl|)))) (T (SETQ |seq| (COND ((NULL |y|) (|bfTuple| NIL)) (T (CADR |y|)))) (|bfReduce| |op| (|bfTupleConstruct| |seq|))))))) |