X-Git-Url: http://git.kpe.io/?p=uffi.git;a=blobdiff_plain;f=uffi-tests.asd;h=ded16f72e102337e503cad106ad75956bf104f85;hp=6f2c4bfc7c129149caaaf776c756afc6f6d583cb;hb=HEAD;hpb=7c6a7667f14741d85625f4091e931f1d5ed42159 diff --git a/uffi-tests.asd b/uffi-tests.asd index 6f2c4bf..ded16f7 100644 --- a/uffi-tests.asd +++ b/uffi-tests.asd @@ -7,50 +7,62 @@ ;;;; Author: Kevin M. Rosenberg ;;;; Date Started: Apr 2003 ;;;; -;;;; $Id$ ;;;; ************************************************************************* (defpackage #:uffi-tests-system (:use #:asdf #:cl)) (in-package #:uffi-tests-system) -(defvar *asd-file-dir* (pathname-directory *load-truename*)) +(operate 'load-op 'uffi) + +(defvar *library-file-dir* (append (pathname-directory *load-truename*) + (list "tests"))) (defclass uffi-test-source-file (c-source-file) ()) (defmethod output-files ((o compile-op) (c uffi-test-source-file)) - (let ((searched (or - (probe-file #p"/usr/lib/uffi/uffi-c-test.so") - (probe-file (make-pathname - :directory *asd-file-dir* - :name "uffi-c-test" - :type "so"))))) - (if searched - (list searched) - (list (merge-pathnames - (make-pathname :name (component-name c) - :type "so" - :directory '(:relative "tests")) - (make-pathname :directory *asd-file-dir*)))))) + (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" "uffi"))))) + (list (if found + found + (make-pathname :name (component-name c) + :type library-file-type + :directory *library-file-dir*))))) (defmethod perform ((o load-op) (c uffi-test-source-file)) - (dolist (f (asdf::input-files o c)) - (funcall (intern (symbol-name '#:load-foreign-library) - (symbol-name '#:uffi)) - f :module "uffi_tests"))) + nil) ;;; library will be loaded by a loader file + +(defmethod operation-done-p ((o load-op) (c uffi-test-source-file)) + (and (symbol-function (intern (symbol-name '#:cs-count-upper) + (find-package '#:uffi-tests))) + t)) (defmethod perform ((o compile-op) (c uffi-test-source-file)) - (unless (zerop (run-shell-command "cd ~A; make" - (namestring (merge-pathnames - (make-pathname - :name nil - :type nil - :directory '(:relative "tests")) - (make-pathname - :directory *asd-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 uffi-test-source-file)) + (or (and (probe-file #p"/usr/lib/uffi/uffi-c-test.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))))))) (defsystem uffi-tests :depends-on (:uffi) @@ -58,8 +70,8 @@ ((:module tests :components ((:file "rt") - (:uffi-test-source-file "uffi-c-test") (:file "package" :depends-on ("rt")) + (:uffi-test-source-file "uffi-c-test" :depends-on ("package")) (:file "strtol" :depends-on ("package")) (:file "atoifl" :depends-on ("package")) (:file "getenv" :depends-on ("package")) @@ -67,13 +79,14 @@ (:file "union" :depends-on ("package")) (:file "arrays" :depends-on ("package")) (:file "structs" :depends-on ("package")) - (:file "pointers" :depends-on ("package")) + (:file "objects" :depends-on ("package")) (:file "time" :depends-on ("package")) (:file "foreign-loader" :depends-on ("package" "uffi-c-test")) (:file "uffi-c-test-lib" :depends-on ("foreign-loader")) (:file "compress" :depends-on ("foreign-loader")) (:file "casts" :depends-on ("foreign-loader")) (:file "foreign-var" :depends-on ("foreign-loader")) + (:file "i18n" :depends-on ("package")) )))) (defmethod perform ((o test-op) (c (eql (find-system :uffi-tests))))