X-Git-Url: http://git.kpe.io/?p=clsql.git;a=blobdiff_plain;f=clsql-uffi.asd;h=90e77de97a323fd524e46d05551ebe45614e29db;hp=fb22dc102d996c749875bb1672f33df1a149bc2a;hb=83b09c87d38cdaf7ce3da8d5a20aa8c5ee4505bc;hpb=eb9d92a3c98130c7fe3b1bbc63dcfe285d02aba2 diff --git a/clsql-uffi.asd b/clsql-uffi.asd index fb22dc1..90e77de 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,64 +16,9 @@ (in-package cl-user) -;; need to load uffi for below output-files method -(eval-when (:compile-toplevel :load-toplevel :execute) - #+common-lisp-controller (require 'uffi) - #-common-lisp-controller (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"))) - -(defclass clsql-uffi-source-file (c-source-file) - ()) - - -(defmethod output-files ((o compile-op) (c clsql-uffi-source-file)) - (let* ((library-file-type - (funcall (intern (symbol-name'#:default-foreign-library-type) - (symbol-name '#:uffi)))) - (found - (some #'(lambda (dir) - (probe-file (make-pathname - :directory dir - :name (component-name c) - :type library-file-type))) - '((:absolute "usr" "lib" "clsql"))))) - (list (if found - found - (make-pathname :name (component-name c) - :type library-file-type - :directory *library-file-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) - (find-package '#:clsql-uffi))) - t)) - -(defmethod perform ((o compile-op) (c clsql-uffi-source-file)) - #-(or win32 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-uffi-source-file)) - (or (and (probe-file #p"/usr/lib/clsql/uffi.so") t) - (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 allegro lispworks cmu sbcl openmcl mcl scl) (defsystem clsql-uffi :name "cl-sql-base" :author "Kevin M. Rosenberg " @@ -84,12 +27,12 @@ :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-base) - + :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")) - (:file "clsql-uffi" :depends-on ("clsql-uffi-loader")))))) + (:file "clsql-uffi-loader" :depends-on ("clsql-uffi-package")) + (:file "clsql-uffi" :depends-on ("clsql-uffi-package"))))))