X-Git-Url: http://git.kpe.io/?p=clsql.git;a=blobdiff_plain;f=clsql-uffi.asd;h=5629d45b5c3a80d12cdae7afd5295da0507d6927;hp=51eb3f1239900ee8e0fb857f82cc2d49f2ff616a;hb=91eb9f3d1335fed9ee9e4644eacca2b97db30836;hpb=f3a8fc0bb7432ed7f9c9a1d2a5bc83e0b494aa6e diff --git a/clsql-uffi.asd b/clsql-uffi.asd index 51eb3f1..5629d45 100644 --- a/clsql-uffi.asd +++ b/clsql-uffi.asd @@ -7,9 +7,7 @@ ;;;; Programmer: Kevin M. Rosenberg ;;;; Date Started: Aug 2002 ;;;; -;;;; $Id$ -;;;; -;;;; This file, part of CLSQL, is Copyright (c) 2002 by Kevin M. Rosenberg +;;;; This file, part of CLSQL, is Copyright (c) 2002-2010 by Kevin M. Rosenberg ;;;; ;;;; CLSQL users are granted the rights to distribute and use this software ;;;; as governed by the terms of the Lisp Lesser GNU Public License @@ -18,16 +16,12 @@ (in-package cl-user) -;; need to load uffi for below output-files method -(eval-when (:compile-toplevel :load-toplevel :execute) - (unless (find-package 'uffi) - (asdf:operate 'asdf:load-op 'uffi))) - (defpackage clsql-uffi-system (:use #:asdf #:cl)) (in-package clsql-uffi-system) -(defvar *library-file-dir* (append (pathname-directory *load-truename*) - (list "uffi"))) +(defvar *clsql-uffi-library-dir* + (merge-pathnames "uffi/" + (make-pathname :name nil :type nil :defaults *load-truename*))) (defclass clsql-uffi-source-file (c-source-file) ()) @@ -48,34 +42,34 @@ found (make-pathname :name (component-name c) :type library-file-type - :directory *library-file-dir*))))) + :defaults *clsql-uffi-library-dir*))))) (defmethod perform ((o load-op) (c clsql-uffi-source-file)) nil) ;;; library will be loaded by a loader file (defmethod operation-done-p ((o load-op) (c clsql-uffi-source-file)) - (and (symbol-function (intern (symbol-name '#:atol64) + (and (find-package '#:clsql-uffi) + (symbol-function (intern (symbol-name '#:atol64) (find-package '#:clsql-uffi))) t)) (defmethod perform ((o compile-op) (c clsql-uffi-source-file)) (unless (operation-done-p o c) - #-(or win32 mswindows) + #-(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*)))) + #-(or freebsd netbsd) "cd ~A; make" + #+(or freebsd netbsd) "cd ~A; gmake" + (namestring *clsql-uffi-library-dir*))) (error 'operation-error :component c :operation o)))) (defmethod operation-done-p ((o compile-op) (c clsql-uffi-source-file)) (or (and (probe-file #p"/usr/lib/clsql/clsql_uffi.so") t) (let ((lib (make-pathname :defaults (component-pathname c) - :type (uffi:default-foreign-library-type)))) + :type (funcall (intern (symbol-name '#:default-foreign-library-type) + (find-package '#:uffi)))))) (and (probe-file lib) (probe-file (component-pathname c)) (> (file-write-date lib) (file-write-date (component-pathname c))))))) - + (defsystem clsql-uffi :name "cl-sql-base" :author "Kevin M. Rosenberg " @@ -84,12 +78,13 @@ :description "Common UFFI Helper functions for Common Lisp SQL Interface Library" :long-description "cl-sql-uffi package provides common helper functions using the UFFI for the CLSQL package." - :depends-on (uffi clsql) - + :depends-on (clsql #-:clsql-cffi (:version uffi "2.0") + #+:clsql-cffi cffi-uffi-compat) + :components ((:module :uffi :components ((:file "clsql-uffi-package") - (:clsql-uffi-source-file "uffi" :depends-on ("clsql-uffi-package")) - (:file "clsql-uffi-loader" :depends-on ("clsql-uffi-package" "uffi")) + (:clsql-uffi-source-file "clsql_uffi" :depends-on ("clsql-uffi-package")) + (:file "clsql-uffi-loader" :depends-on ("clsql-uffi-package" "clsql_uffi")) (:file "clsql-uffi" :depends-on ("clsql-uffi-loader"))))))