100 lines
2.6 KiB
Common Lisp
100 lines
2.6 KiB
Common Lisp
(defpackage #:cl-info/core
|
|
(:nicknames #:cl-info)
|
|
(:use #:cl)
|
|
(:export
|
|
#:cl-info
|
|
#:get-asdf-version
|
|
#:get-lisp-type
|
|
#:get-lisp-version
|
|
#:get-software-type
|
|
#:get-software-version
|
|
#:get-ql-dists
|
|
#:make-cl-info
|
|
#:system-info
|
|
#:get-name
|
|
#:get-version
|
|
#:get-path
|
|
#:absent-p
|
|
#:make-system-info))
|
|
(in-package cl-info/core)
|
|
|
|
|
|
(defclass cl-info ()
|
|
((asdf-version :initform (asdf:asdf-version)
|
|
:reader get-asdf-version)
|
|
(lisp-type :initform (lisp-implementation-type)
|
|
:reader get-lisp-type)
|
|
(lisp-version :initform (lisp-implementation-version)
|
|
:reader get-lisp-version)
|
|
(software-type :initform (software-type)
|
|
:reader get-software-type)
|
|
(software-version :initform (software-version)
|
|
:reader get-software-version)
|
|
(ql-dists :initform (ql-dist:all-dists)
|
|
:reader get-ql-dists)))
|
|
|
|
|
|
(defclass system-info ()
|
|
((name :initarg :name
|
|
:reader get-name)
|
|
(version :initarg :version
|
|
:reader get-version)
|
|
(path :initarg :path
|
|
:reader get-path)
|
|
(absent :initarg :absent
|
|
:initform nil
|
|
:reader absent-p)))
|
|
|
|
|
|
(defmethod print-object ((info cl-info) stream)
|
|
(format stream
|
|
"OS: ~A ~A
|
|
Lisp: ~A ~A
|
|
ASDF: ~A
|
|
QL: ~{~A~^~%~}
|
|
"
|
|
(get-software-type info)
|
|
(get-software-version info)
|
|
(get-lisp-type info)
|
|
(get-lisp-version info)
|
|
(get-asdf-version info)
|
|
(loop for dist in (get-ql-dists info)
|
|
for idx upfrom 0
|
|
collect (format nil "~:[~; ~]~A ~A"
|
|
(> idx 0)
|
|
(ql-dist:name dist)
|
|
(ql-dist:version dist)))))
|
|
|
|
|
|
(defmethod print-object ((info system-info) stream)
|
|
(if (absent-p info)
|
|
(format stream
|
|
"System: ~A is not available"
|
|
(get-name info))
|
|
(format stream
|
|
"System: ~A ~A
|
|
~A
|
|
"
|
|
(get-name info)
|
|
(get-version info)
|
|
(get-path info))))
|
|
|
|
|
|
(defun make-cl-info ()
|
|
(make-instance 'cl-info))
|
|
|
|
|
|
(defun make-system-info (system-name)
|
|
(let ((system (asdf:find-system system-name)))
|
|
(if system
|
|
(make-instance 'system-info
|
|
:name system-name
|
|
:version (asdf:component-version system)
|
|
:path (asdf:component-pathname system))
|
|
(make-instance 'system-info
|
|
:name system-name
|
|
:absent-p t
|
|
:version nil
|
|
:path nil))))
|
|
|
|
|