r10801: 4 Nov 2005 Kevin Rosenberg <kevin@rosenberg.net>
[clsql.git] / clsql.asd
index f9e8bff1ac2534971996732e1d2cc37d5aff191b..c70fd787e5c8696dc3d8093715527f3dbae134f6 100644 (file)
--- a/clsql.asd
+++ b/clsql.asd
 (defpackage #:clsql-system (:use #:asdf #:cl))
 (in-package #:clsql-system)
 
-(defsystem #:clsql
+;; need to load uffi for below perform :after method 
+(eval-when (:compile-toplevel :load-toplevel :execute)
+  (unless (find-package 'uffi)
+    (asdf:operate 'asdf:load-op 'uffi)))
+
+(defsystem clsql
     :name "CLSQL"
     :author "Kevin Rosenberg <kevin@rosenberg.net>"
     :maintainer "Kevin M. Rosenberg <kmr@debian.org>"
@@ -31,7 +36,7 @@ oriented interface."
     :components
     ((:module sql
              :components
-             ((:module :base
+             ((:module base
                        :pathname ""
                        :components
                        ((:file "cmucl-compat")
@@ -43,43 +48,50 @@ oriented interface."
                         (:file "time" :depends-on ("package" "conditions"))
                         (:file "utils" :depends-on ("package" "db-interface"))
                          (:file "generics" :depends-on ("package"))))
-               (:module :database 
-                        :pathname "" 
-                        :components 
+               (:module database
+                        :pathname ""
+                        :components
                         ((:file "initialize")
                         (:file "database" :depends-on ("initialize"))
                         (:file "recording" :depends-on ("database"))
                         (:file "pool"))
-                        :depends-on (:base))
-              (:module :syntax
+                        :depends-on (base))
+              (:module syntax
                        :pathname ""
                        :components ((:file "expressions")
-                                    (:file "operations" 
+                                    (:file "operations"
                                             :depends-on ("expressions"))
                                     (:file "syntax" :depends-on ("operations")))
-                       :depends-on (:database))
-              (:module :functional
+                       :depends-on (database))
+              (:module functional
                        :pathname ""
                        :components ((:file "fdml")
                                      (:file "transaction" :depends-on ("fdml"))
-                                     (:file "loop-extension" 
+                                     (:file "loop-extension"
                                             :depends-on ("fdml"))
                                     (:file "fddl" :depends-on ("fdml")))
-                       :depends-on (:syntax))
-              (:module :object
+                       :depends-on (syntax))
+              (:module object
                        :pathname ""
-                      :components ((:file "metaclasses")
-                                    (:file "ooddl" :depends-on ("metaclasses"))
-                                   (:file "oodml" :depends-on ("ooddl")))
-                      :depends-on (:functional))
-              (:module :generic
+                       :components ((:file "metaclasses")
+                                    (:file "ooddl" :depends-on ("metaclasses"))
+                                    (:file "oodml" :depends-on ("ooddl")))
+                       :depends-on (functional))
+              (:module generic
                        :pathname ""
-                      :components ((:file "generic-postgresql")
-                                   (:file "generic-odbc")
-                                   (:file "sequences"))
-                      :depends-on (:functional))))))
-     
+                       :components ((:file "generic-postgresql")
+                                    (:file "generic-odbc")
+                                    (:file "sequences"))
+                       :depends-on (functional))))))
+
 
 (defmethod perform ((o test-op) (c (eql (find-system 'clsql))))
   (operate 'load-op 'clsql-tests)
   (operate 'test-op 'clsql-tests :force t))
+
+(defmethod perform :after ((o load-op) (c (eql (find-system 'clsql))))
+  (let* ((init-var (uffi:getenv "CLSQLINIT"))
+         (init-file (or (when init-var (probe-file init-var))
+                        (probe-file "/etc/clsql-init.lisp"))))
+    (when init-file (load init-file))))
+