Remove CVS $Id$ keyword
[clsql.git] / db-oracle / oracle-loader.lisp
index 72414029fb862ad234a02ae811f732220d4b66d0..f1493d3a1a585fb0d8c2d103d92a590f5d13b4c0 100644 (file)
@@ -5,8 +5,6 @@
 ;;;; Name:          oracle-loader.lisp
 ;;;; Purpose:       Foreign library loader for CLSQL Oracle interface
 ;;;;
-;;;; $Id$
-;;;;
 ;;;; This file is part of CLSQL.
 ;;;;
 ;;;; CLSQL users are granted the rights to distribute and use this software
       (parse-namestring (concatenate 'string oracle-home "/"))))
   "Pathname of ORACLE_HOME as set in user environment.")
 
-(defparameter *oracle-client-library-path* 
-    (uffi:find-foreign-library
-     '("libclntsh" "oci")
-     `(,@(when *load-truename*
-          (list (make-pathname
-                 :directory (pathname-directory *load-truename*))))
-        ,@(when *oracle-home*
-            (list
-             (make-pathname :defaults *oracle-home*
-                            :directory 
-                            (append (pathname-directory *oracle-home*)
-                                    (list "lib")))
-             (make-pathname :defaults *oracle-home*
-                            :directory 
-                            (append (pathname-directory *oracle-home*)
-                                    (list "bin")))))
-        "/usr/lib/oracle/10.1.0.2/client/lib/")
-     :drive-letters '("C")))
+(defparameter *oracle-client-library-filenames*
+  (list "libclntsh" "oci"))
 
 (defvar *oracle-supporting-libraries* '("c")
   "Used only by CMU. List of library flags needed to be passed to ld to
@@ -53,14 +35,18 @@ set to the right path before compiling or loading the system.")
   *oracle-library-loaded*)
 
 (defmethod clsql-sys:database-type-load-foreign ((database-type (eql :oracle)))
-  (if (pathnamep *oracle-client-library-path*) 
-      (progn
-       (uffi:load-foreign-library *oracle-client-library-path*
-                                  :module "clsql-oracle"
-                                  :supporting-libraries 
-                                  *oracle-supporting-libraries*)
-       (setq *oracle-library-loaded* t))
-      (warn "Unable to load oracle client library.")))
+  (when *oracle-home*
+    (dolist (dir-name '("lib" "bin"))
+      (dolist (lib-name '("libclntsh" "oci"))
+        (clsql:push-library-path
+         (make-pathname :name lib-name
+                        :directory (append (pathname-directory *oracle-home*)
+                                           (list dir-name)))))))
+
+  (clsql-uffi:find-and-load-foreign-library *oracle-client-library-filenames*
+                                            :module "clsql-oracle"
+                                            :supporting-libraries *oracle-supporting-libraries*)
+  (setq *oracle-library-loaded* t))
 
 (clsql-sys:database-type-load-foreign :oracle)