2 (eval-when (:compile-toplevel :load-toplevel :execute)
4 (defpackage #:sb-bsd-sockets-system (:use #:asdf #:sb-grovel #:cl))
5 (in-package #:sb-bsd-sockets-system)
7 ;;; we also have a shared library with some .o files in it
9 (defclass unix-dso (module) ())
10 (defun unix-name (pathname)
13 (logical-pathname (translate-logical-pathname pathname))
16 (defmethod asdf::input-files ((operation compile-op) (dso unix-dso))
17 (mapcar #'component-pathname (module-components dso)))
19 (defmethod output-files ((operation compile-op) (dso unix-dso))
20 (let ((dir (component-pathname dso)))
22 (make-pathname :type "so"
23 :name (car (last (pathname-directory dir)))
24 :directory (butlast (pathname-directory dir))
28 (defmethod perform :after ((operation compile-op) (dso unix-dso))
29 (let ((dso-name (unix-name (car (output-files operation dso)))))
32 "gcc ~A -o ~S ~{~S ~}"
33 (if (sb-ext:posix-getenv "LDFLAGS")
34 (sb-ext:posix-getenv "LDFLAGS")
35 #+sunos "-shared -lresolv -lsocket -lnsl"
37 #-(or darwin sunos) "-shared")
41 (output-files operation c))
42 (module-components dso)))))
43 (error 'operation-error :operation operation :component dso))))
45 ;;; if this goes into the standard asdf, it could reasonably be extended
46 ;;; to allow cflags to be set somehow
47 (defmethod output-files ((op compile-op) (c c-source-file))
49 (make-pathname :type "o" :defaults
50 (component-pathname c))))
51 (defmethod perform ((op compile-op) (c c-source-file))
53 (= 0 (run-shell-command "gcc ~A -o ~S -c ~S"
54 (if (sb-ext:posix-getenv "CFLAGS")
55 (sb-ext:posix-getenv "CFLAGS")
57 (unix-name (car (output-files op c)))
58 (unix-name (component-pathname c))))
59 (error 'operation-error :operation op :component c)))
61 (defmethod perform ((operation load-op) (c c-source-file))
64 (defmethod perform ((o load-op) (c unix-dso))
65 (let ((co (make-instance 'compile-op)))
66 (let ((filename (car (output-files co c))))
67 #+cmu (ext:load-foreign filename)
68 #+sbcl (sb-alien:load-1-foreign filename))))
70 (defsystem sb-bsd-sockets
72 :depends-on (sb-grovel)
73 :components ((:file "defpackage")
74 (:file "split" :depends-on ("defpackage"))
75 (:file "array-data" :depends-on ("defpackage"))
77 :components ((:c-source-file "undefs")
78 (:c-source-file "get-h-errno")))
79 (:file "malloc" :depends-on ("defpackage"))
80 (:file "foreign-glue" :depends-on ("defpackage" "malloc"))
81 (sb-grovel:grovel-constants-file
83 :package :sockint :pathname "constants.lisp"
84 :depends-on ("def-to-lisp" "defpackage" "foreign-glue"))
86 :depends-on ("constants" "array-data"))
88 (:file "sockopt" :depends-on ("sockets"))
89 (:file "inet" :depends-on ("sockets" "split" "constants" ))
90 (:file "local" :depends-on ("sockets" "split" "constants" ))
91 (:file "name-service" :depends-on ("sockets" "constants" "alien"))
92 (:file "misc" :depends-on ("sockets" "constants"))
97 ;; (:static-file "INSTALL")
98 (:static-file "README")
99 (:static-file "index" :pathname "index.html")
100 (:static-file "doc" :pathname "doc.lisp")
101 (:static-file "TODO")))
103 (defmethod perform :after ((o load-op) (c (eql (find-system :sb-bsd-sockets))))
104 (provide 'sb-bsd-sockets))
106 (defmethod perform ((o test-op) (c (eql (find-system :sb-bsd-sockets))))
107 (operate 'load-op 'sb-bsd-sockets-tests)
108 (operate 'test-op 'sb-bsd-sockets-tests))
110 (defsystem sb-bsd-sockets-tests
111 :depends-on (sb-rt sb-bsd-sockets)
112 :components ((:file "tests")))
114 (defmethod perform ((o test-op) (c (eql (find-system :sb-bsd-sockets-tests))))
115 (or (funcall (intern "DO-TESTS" (find-package "SB-RT")))
116 (error "test-op failed")))