~ chicken-core (chicken-5) 16ca275815f78bf6338e17938e5e16078cff085a


commit 16ca275815f78bf6338e17938e5e16078cff085a
Author:     felix <felix@call-with-current-continuation.org>
AuthorDate: Mon Mar 14 12:34:50 2011 +0100
Commit:     felix <felix@call-with-current-continuation.org>
CommitDate: Mon Mar 14 12:34:50 2011 +0100

    simpler qq simplification; runtests removes some stale files

diff --git a/expand.scm b/expand.scm
index cd3b823c..2c4b65d3 100644
--- a/expand.scm
+++ b/expand.scm
@@ -1389,11 +1389,12 @@
                         (cond ((eq? n 0)
                                (##sys#check-syntax 'unquote x '(_ _))
                                (car tail))
-                              (else (list '##sys#cons `(##core#quote ,%unquote)
-                                          (walk tail (fx- n 1)) ) )))
+                              (else
+			       `(##sys#cons (##core#quote ,%unquote)
+					    (walk tail (fx- n 1)) ) )))
 		       ((c %quasiquote head)
-			(list '##sys#cons `(##core#quote ,%quasiquote) 
-                              (walk tail (fx+ n 1)) ) )
+			`(##sys#cons (##core#quote ,%quasiquote) 
+				     (walk tail (fx+ n 1)) ) )
 		       ((and (pair? head) (c %unquote-splicing (car head)))
                         (cond ((eq? n 0)
                                (##sys#check-syntax 'unquote-splicing head '(_ _))
@@ -1406,21 +1407,14 @@
 		       (else
 			`(##sys#cons ,(walk head n) ,(walk tail n)) ) ) ) ) ) )
       (define (simplify x)
-	(cond ((match-expression x '(##sys#cons a (##core#quote ())) '(a))
-	       => (lambda (env) (simplify `(##sys#list ,(cdr (assq 'a env))))) )
-	      ((match-expression x '(##sys#cons a (##sys#list . b)) '(a b))
-	       => (lambda (env)
-		    (let ((bxs (assq 'b env)))
-		      (if (fx< (length bxs) 32)
-			  (simplify `(##sys#list ,(cdr (assq 'a env)) ,@(cdr bxs) ) ) 
-			  x) ) ) )
-	      ((match-expression x '(##sys#cons a b) '(a b))
+	(cond ((match-expression x '(##sys#cons a b) '(a b))
 	       => (lambda (env) 
 		    `(##sys#cons 
 		      ,(simplify (cdr (assq 'a env)))
 		      ,(simplify (cdr (assq 'b env))))))
 	      ((match-expression x '(##sys#append a (##core#quote ())) '(a))
-	       => (lambda (env) (cdr (assq 'a env))) )
+	       => (lambda (env) 
+		    (simplify (cdr (assq 'a env))) ))
 	      (else x) ) )
       (##sys#check-syntax 'quasiquote form '(_ _))
       (walk (cadr form) 0) ) ) ) )
diff --git a/tests/runtests.sh b/tests/runtests.sh
index 4f6677d4..545c086e 100644
--- a/tests/runtests.sh
+++ b/tests/runtests.sh
@@ -39,6 +39,8 @@ if test -n "$MSYSTEM"; then
     cp ../libchicken.dll .
 fi
 
+rm -f a.out *.exe *.import.* *.so
+
 compile="../csc -compiler $CHICKEN -v -I.. -L.. -include-path .. -o a.out"
 compile_s="../csc -s -compiler $CHICKEN -v -I.. -L.. -include-path .."
 interpret="../csi -n -include-path .."
Trap