~ chicken-core (chicken-5) 1b0996e966da46d3bb02dc46a6dab3545fe5cbbe


commit 1b0996e966da46d3bb02dc46a6dab3545fe5cbbe
Author:     unknown <felix@.(none)>
AuthorDate: Tue Nov 3 14:50:33 2009 +0100
Commit:     unknown <felix@.(none)>
CommitDate: Tue Nov 3 14:50:33 2009 +0100

    import-library is only generated if changed or doesn't exist (suggested by Joerg Wittenberger)

diff --git a/compiler.scm b/compiler.scm
index 7680ec99..8ae2907d 100644
--- a/compiler.scm
+++ b/compiler.scm
@@ -485,21 +485,27 @@
        '() ) ))
 
   (define (emit-import-lib name il)
-    (let ((fname (if all-import-libraries
-		     (string-append (symbol->string name) ".import.scm")
-		     (cdr il))))
-      (when verbose-mode
-	(print "generating import library " fname " for module "
-	       name " ..."))
-      (with-output-to-file fname
-	(lambda ()
-	  (print ";;;; " fname " - GENERATED BY CHICKEN "
-		 (chicken-version) " -*- Scheme -*-\n")
-	  (for-each
-	   pretty-print
-	   (##sys#compiled-module-registration
-	    (##sys#current-module)))
-	  (print "\n;; END OF FILE")))))
+    (let* ((fname (if all-import-libraries
+		      (string-append (symbol->string name) ".import.scm")
+		      (cdr il)))
+	   (imps (##sys#compiled-module-registration (##sys#current-module)))
+	   (oldimps
+	    (and (file-exists? fname)
+		 (read-file fname) ) ) )
+      (cond ((equal? imps oldimps)
+	     (when verbose-mode
+	       (print "not generating import library `" fname "' for module `" 
+		      name "' because imports did not change")) )
+	    (else
+	     (when verbose-mode
+	       (print "generating import library `" fname "' for module `"
+		      name "' ..."))
+	     (with-output-to-file fname
+	       (lambda ()
+		 (print ";;;; " fname " - GENERATED BY CHICKEN "
+			(chicken-version) " -*- Scheme -*-\n")
+		 (for-each pretty-print imps)
+		 (print "\n;; END OF FILE"))))) ) )
 
   (define (walk x e se dest)
     (cond ((symbol? x)
Trap