Work at SourceForge, help us to make it a better place! We have an immediate need for a Support Technician in our San Francisco or Denver office.

Close

[25c176]: contrib / sb-introspect / sb-introspect.asd Maximize Restore History

Download this file

sb-introspect.asd    79 lines (69 with data), 3.3 kB

;;; -*-  Lisp -*-

;;;; This software is part of the SBCL system. See the README file for
;;;; more information.
;;;;
;;;; This software is derived from the CMU CL system, which was
;;;; written at Carnegie Mellon University and released into the
;;;; public domain. The software is in the public domain and is
;;;; provided with absolutely no warranty. See the COPYING and CREDITS
;;;; files for more information.

(defpackage #:sb-introspect-system (:use :cl :asdf :uiop))
(in-package #:sb-introspect-system)

(defsystem :sb-introspect
  :components ((:file "introspect"))
  #+sb-building-contrib :pathname
  #+sb-building-contrib #p"SYS:CONTRIB;SB-INTROSPECT;"
  :perform (load-op :after (o c) (provide 'sb-introspect))
  :perform (test-op (o c) (test-system :sb-introspect/tests)))

(defclass plist-file (cl-source-file)
  ((source-plist
    :initform nil
    :initarg :source-plist
    :reader plist-file-source-plist)))

(defmethod perform ((op compile-op) (com plist-file))
  (with-compilation-unit (:source-plist (plist-file-source-plist com))
    (call-next-method)))

(defmethod perform ((op load-op) (com plist-file))
  (with-compilation-unit (:source-plist (plist-file-source-plist com))
    (call-next-method)))

(defclass source-only-file (cl-source-file)
  ())

(defmethod perform ((op compile-op) (com source-only-file)))
(defmethod perform ((op load-op) (com source-only-file)))
(defmethod output-files ((op compile-op) (com source-only-file))
  ())
(defmethod component-depends-on ((op load-op) (com source-only-file))
  `((load-source-op ,com) ,@(call-next-method)))

(defsystem :sb-introspect/tests
  :depends-on (:sb-introspect :sb-rt)
  #+sb-building-contrib :pathname
  #+sb-building-contrib #p"SYS:CONTRIB;SB-INTROSPECT;"
  :components ((:file "xref-test-data")
               (:file "xref-test" :depends-on ("xref-test-data"))
               (:plist-file "test" :source-plist (:test-outer "OUT") :operation-done-p (compile-op (o c) nil))
               (:source-only-file "load-test")
               (:file "test-driver" :depends-on ("test" "load-test")))
  :perform
  (test-op (o c)
    ;; N.b. At least DEFINITION-SOURCE-PLIST.1 assumes that CWD is the
    ;; contrib/sb-introspect directory which is true for when this is
    ;; implicitly run via make-target-contribs.sh -- but not when this
    ;; is executed manually.
    (let ((*default-pathname-defaults* (translate-logical-pathname (system-source-directory c))))
      (multiple-value-bind (soft strict pending) (symbol-call :sb-rt :do-tests)
        (declare (ignorable pending))
        (fresh-line)
        (unless strict
          #+sb-testing-contrib
          ;; We create TEST-PASSED from a shell script if tests passed.  But
          ;; since the shell script only `touch'es it, we can actually create
          ;; it ahead of time -- as long as we're certain that tests truly
          ;; passed, hence the check for SOFT.
          (when soft
            (with-open-file (s #p"SYS:CONTRIB;SB-INTROSPECT;TEST-PASSED"
                               :direction :output)
              (dolist (pend pending)
                (format s "Expected failure: ~A~%" pend))))
          (warn "ignoring expected failures in test-op"))
        (unless soft
          (error "test-op failed with unexpected failures"))))))