~ chicken-core (chicken-5) 639896ed406e57020a64e07f17c319718ee83978


commit 639896ed406e57020a64e07f17c319718ee83978
Author:     Evan Hanson <evhan@foldling.org>
AuthorDate: Sun Dec 29 14:46:39 2013 +1300
Commit:     Peter Bex <peter.bex@xs4all.nl>
CommitDate: Thu Jan 9 21:51:56 2014 +0100

    Remove some redundant/unreachable cases in type matching
    
    Signed-off-by: Peter Bex <peter.bex@xs4all.nl>

diff --git a/scrutinizer.scm b/scrutinizer.scm
index 0cdd4f23..d7b7dfa7 100644
--- a/scrutinizer.scm
+++ b/scrutinizer.scm
@@ -1126,12 +1126,10 @@
 	  ((eq? t2 'vector) (match1 t1 '(vector-of *)))
 	  ((eq? t1 'null)
 	   (and (not exact) (not all)
-		(or (memq t2 '(null list))
-		    (and (pair? t2) (eq? 'list-of (car t2))))))
+		(pair? t2) (eq? 'list-of (car t2))))
 	  ((eq? t2 'null)
 	   (and (not exact)
-		(or (memq t1 '(null list))
-		    (and (pair? t1) (eq? 'list-of (car t1))))))
+		(pair? t1) (eq? 'list-of (car t1))))
 	  ((and (pair? t1) (pair? t2) (eq? (car t1) (car t2)))
 	   (case (car t1)
 	     ((procedure)
@@ -1192,17 +1190,10 @@
 			  typeenv
 			  #t
 			  (lambda (t) (match1 t1 t)))))
-		      ((pair)
-		       (let ((ct2 (canonicalize-list-type t2)))
-			 (and ct2 (match1 t1 ct2))))
 		      (else #f)))))
 	  ((and (pair? t1) (eq? 'list (car t1)))
 	   (and (pair? t2)
 		(case (car t2)
-		  ((pair)
-		   (and (pair? (cdr t1))
-			(match1 (second t1) (second t2))
-			(match1 t1 (third t2))))
 		  ((list-of)
 		   (and (not exact) 
 			(not all)
@@ -1213,22 +1204,6 @@
 			   #t
 			   (lambda (t) (match1 t t2))))))
 		  (else #f))))
-	  ((and (pair? t2) (eq? 'list-of (car t2)))
-	   (and (not exact)		;XXX also check "all"?
-		(or (eq? 'null t1)
-		    (and (pair? t1)
-			 (eq? 'pair (car t1)) ; list-of already handled above
-			 (let ((ct1 (canonicalize-list-type t1)))
-			   (and ct1 (match1 ct1 t2)))))))
-	  ((and (pair? t2) (eq? 'list (car t2)))
-	   (and (pair? t1)
-		(case (car t1)
-		  ((pair)
-		   (and (pair? (cdr t2))
-			(match1 (second t1) (second t2))
-			(match1 (third t1) t2)))
-		  ;; t1 = list-of already handled above
-		  (else #f))))
 	  ((and (pair? t1) (eq? 'vector (car t1)))
 	   (and (not exact) (not all)
 		(pair? t2)
Trap