(in-package #:clsql-mysql-system)
(eval-when (:compile-toplevel :load-toplevel :execute)
- #+common-lisp-controller (require 'uffi)
- #-common-lisp-controller (asdf:operate 'asdf:load-op 'uffi))
+ (unless (find-package 'uffi)
+ (asdf:operate 'asdf:load-op 'uffi)))
(defvar *library-file-dir* (append (pathname-directory *load-truename*)
(list "db-mysql")))
(probe-file (make-pathname :directory dir
:name (component-name c)
:type library-file-type)))
- '((:absolute "usr" "lib" "clsql")))))
+ '((:absolute "usr" "lib" "clsql")))))
(list (if found
found
(make-pathname :name (component-name c)
:directory *library-file-dir*)))))
(defmethod perform ((o load-op) (c clsql-mysql-source-file))
- nil) ;;; library will be loaded by a loader file
+ t)
(defmethod operation-done-p ((o load-op) (c clsql-mysql-source-file))
- nil)
+ (and (symbol-function (intern (symbol-name '#:mysql-get-client-info)
+ (find-package '#:mysql)))
+ t))
(defmethod perform ((o compile-op) (c clsql-mysql-source-file))
- #-(or win32 mswindows)
- (unless (zerop (run-shell-command
- "cd ~A; make"
- (namestring (make-pathname :name nil
- :type nil
- :directory *library-file-dir*))))
- (error 'operation-error :component c :operation o)))
+ (unless (operation-done-p o c)
+ #-(or win32 win64 windows mswindows)
+ (unless (zerop (run-shell-command
+ #-freebsd "cd ~A; make"
+ #+freebsd "cd ~A; gmake"
+ (namestring (make-pathname :name nil
+ :type nil
+ :directory *library-file-dir*))))
+ (error 'operation-error :component c :operation o))))
(defmethod operation-done-p ((o compile-op) (c clsql-mysql-source-file))
- (let ((lib (make-pathname :defaults (component-pathname c)
- :type (uffi:default-foreign-library-type))))
- (and (probe-file lib)
- (> (file-write-date lib) (file-write-date (component-pathname c))))))
+ (or (and (probe-file #p"/usr/lib/clsql/clsql_mysql.so") t)
+ (let ((lib (make-pathname :defaults (component-pathname c)
+ :type (uffi:default-foreign-library-type))))
+ (and (probe-file lib) (probe-file (component-pathname c))
+ (> (file-write-date lib) (file-write-date (component-pathname c)))))))
;;; System definition
-#+(or allegro lispworks cmu sbcl openmcl mcl scl)
(defsystem :clsql-mysql
:name "cl-sql-mysql"
:author "Kevin M. Rosenberg <kmr@debian.org>"
:description "Common Lisp SQL MySQL Driver"
:long-description "cl-sql-mysql package provides a database driver to the MySQL database system."
- :depends-on (uffi clsql-base clsql-uffi)
+ :depends-on (uffi clsql clsql-uffi)
:components
((:module :db-mysql
:components
- ((:clsql-mysql-source-file "mysql")
- (:file "mysql-package")
- (:file "mysql-loader" :depends-on ("mysql-package" "mysql"))
+ ((:file "mysql-package")
+ (:clsql-mysql-source-file "clsql_mysql" :depends-on ("mysql-package"))
+ (:file "mysql-loader" :depends-on ("mysql-package" "clsql_mysql"))
(:file "mysql-client-info" :depends-on ("mysql-loader"))
(:file "mysql-api" :depends-on ("mysql-client-info"))
- (:file "mysql-sql" :depends-on ("mysql-api"))))))
+ (:file "mysql-sql" :depends-on ("mysql-api"))
+ (:file "mysql-objects" :depends-on ("mysql-sql"))))))