Now cl-info is able to work without Quicklisp client.
Also: * make-cl-info was renamed to get-cl-info. * make-system-info was renamed to get-system-info.
This commit is contained in:
parent
ec68cbb024
commit
5b48e49e37
5 changed files with 55 additions and 34 deletions
|
@ -2,6 +2,16 @@
|
||||||
ChangeLog
|
ChangeLog
|
||||||
===========
|
===========
|
||||||
|
|
||||||
|
0.4.0 (2019-07-19)
|
||||||
|
==================
|
||||||
|
|
||||||
|
Now cl-info is able to work without Quicklisp client.
|
||||||
|
|
||||||
|
Also:
|
||||||
|
|
||||||
|
* ``make-cl-info`` was renamed to ``get-cl-info``.
|
||||||
|
* ``make-system-info`` was renamed to ``get-system-info``.
|
||||||
|
|
||||||
0.3.0 (2018-06-17)
|
0.3.0 (2018-06-17)
|
||||||
==================
|
==================
|
||||||
|
|
||||||
|
|
40
README.rst
40
README.rst
|
@ -18,35 +18,35 @@ Lisp environment.
|
||||||
Usage from Common Lisp
|
Usage from Common Lisp
|
||||||
======================
|
======================
|
||||||
|
|
||||||
It's main call is ``(cl-info:make-cl-info)``, it returns an object with
|
It's main call is ``(cl-info:get-cl-info)``, it returns an object with
|
||||||
customized ``print-object`` method. You can use it to output debug
|
customized ``print-object`` method. You can use it to output debug
|
||||||
information in your programs:
|
information in your programs:
|
||||||
|
|
||||||
.. code:: common-lisp
|
.. code:: common-lisp
|
||||||
|
|
||||||
CL-USER> (cl-info:make-cl-info)
|
CL-USER> (cl-info:get-cl-info)
|
||||||
OS: Darwin 15.6.0
|
OS: Darwin 15.6.0
|
||||||
Lisp: SBCL 1.4.8
|
Lisp: SBCL 1.4.8
|
||||||
ASDF: 3.3.1.1
|
ASDF: 3.3.1.1
|
||||||
QL: ceramic github-e0d905187946f8f2358f7b05e1ce87b302e34312
|
QL: ceramic github-e0d905187946f8f2358f7b05e1ce87b302e34312
|
||||||
cl-prevalence github-c163c227ed85d430b82cb1e3502f72d4f88e3cfa
|
cl-prevalence github-c163c227ed85d430b82cb1e3502f72d4f88e3cfa
|
||||||
log4cl-json github-c4f786e252d89a45372186aaf32fb8e8736b444b
|
log4cl-json github-c4f786e252d89a45372186aaf32fb8e8736b444b
|
||||||
log4cl github-6a857b0b41c030a8a3b04096205e221baaa1755f
|
log4cl github-6a857b0b41c030a8a3b04096205e221baaa1755f
|
||||||
quicklisp 2018-04-30
|
quicklisp 2018-04-30
|
||||||
slynk github-3314cf8c3021cb758e0e30fe3ece54accf1dcf3d
|
slynk github-3314cf8c3021cb758e0e30fe3ece54accf1dcf3d
|
||||||
weblocks-lass github-1b043afbf2f3e84e495dfeae5e63fe67a435019f
|
weblocks-lass github-1b043afbf2f3e84e495dfeae5e63fe67a435019f
|
||||||
weblocks-parenscript github-8ef4ca2f837403a05c4e9b92dcf1c41771d16f17
|
weblocks-parenscript github-8ef4ca2f837403a05c4e9b92dcf1c41771d16f17
|
||||||
weblocks-ui github-5afdf238534d70edc2447d0bc8bc63da8e35999f
|
weblocks-ui github-5afdf238534d70edc2447d0bc8bc63da8e35999f
|
||||||
weblocks-websocket github-b098db7f179dce3bfb045afd4e35e7cc868893f0
|
weblocks-websocket github-b098db7f179dce3bfb045afd4e35e7cc868893f0
|
||||||
weblocks github-282483f97d6ca351265ebfebb017867c295d01ad
|
weblocks github-282483f97d6ca351265ebfebb017867c295d01ad
|
||||||
websocket-driver github-a3046b11dfb9803ac3bff7734dd017390c2b54bb
|
websocket-driver github-a3046b11dfb9803ac3bff7734dd017390c2b54bb
|
||||||
CL-USER>
|
CL-USER>
|
||||||
|
|
||||||
Also, you can gather information about separate systems:
|
Also, you can gather information about separate systems:
|
||||||
|
|
||||||
.. code:: common-lisp
|
.. code:: common-lisp
|
||||||
|
|
||||||
CL-USER> (cl-info:make-system-info :hamcrest)
|
CL-USER> (cl-info:get-system-info :hamcrest)
|
||||||
System: HAMCREST 0.4.2
|
System: HAMCREST 0.4.2
|
||||||
/Users/art/common-lisp/cl-hamcrest/src/
|
/Users/art/common-lisp/cl-hamcrest/src/
|
||||||
|
|
||||||
|
@ -70,14 +70,14 @@ Here how to do it:
|
||||||
OS: Darwin 15.6.0
|
OS: Darwin 15.6.0
|
||||||
Lisp: Clozure Common Lisp Version 1.11.5/v1.11.5 (DarwinX8664)
|
Lisp: Clozure Common Lisp Version 1.11.5/v1.11.5 (DarwinX8664)
|
||||||
ASDF: 3.3.1.1
|
ASDF: 3.3.1.1
|
||||||
QL: org.borodust.bodge 20180214223017
|
QL: org.borodust.bodge 20180214223017
|
||||||
quicklisp 2017-10-23
|
quicklisp 2017-10-23
|
||||||
System: weblocks 0.31.1
|
System: weblocks 0.31.1
|
||||||
/Users/art/common-lisp/weblocks/src/
|
/Users/art/common-lisp/weblocks/src/
|
||||||
System: clack 2.0.0
|
System: clack 2.0.0
|
||||||
/Users/art/common-lisp/clack/
|
/Users/art/common-lisp/clack/
|
||||||
System: jonathan 0.1
|
System: jonathan 0.1
|
||||||
/Users/art/.roswell/lisp/quicklisp/dists/quicklisp/software/jonathan-20170630-git/
|
/Users/art/.roswell/lisp/quicklisp/dists/quicklisp/software/jonathan-20170630-git/
|
||||||
System: some-other-system is not available
|
System: some-other-system is not available
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -12,8 +12,8 @@ exec ros -Q -- $0 "$@"
|
||||||
(defpackage :ros.script.cl-info
|
(defpackage :ros.script.cl-info
|
||||||
(:use :cl)
|
(:use :cl)
|
||||||
(:import-from #:cl-info/core
|
(:import-from #:cl-info/core
|
||||||
#:make-cl-info
|
#:get-cl-info
|
||||||
#:make-system-info)
|
#:get-system-info)
|
||||||
(:import-from #:defmain
|
(:import-from #:defmain
|
||||||
#:defmain))
|
#:defmain))
|
||||||
(in-package :ros.script.cl-info)
|
(in-package :ros.script.cl-info)
|
||||||
|
@ -30,9 +30,9 @@ exec ros -Q -- $0 "$@"
|
||||||
(format t "Version: ~A~%" version)
|
(format t "Version: ~A~%" version)
|
||||||
(uiop:quit 0)))
|
(uiop:quit 0)))
|
||||||
|
|
||||||
(princ (make-cl-info))
|
(princ (get-cl-info))
|
||||||
|
|
||||||
(loop for system-name in system
|
(loop for system-name in system
|
||||||
do (princ (make-system-info system-name))))
|
do (princ (get-system-info system-name))))
|
||||||
|
|
||||||
;;; vim: set ft=lisp lisp:
|
;;; vim: set ft=lisp lisp:
|
||||||
|
|
|
@ -9,13 +9,13 @@
|
||||||
#:get-software-type
|
#:get-software-type
|
||||||
#:get-software-version
|
#:get-software-version
|
||||||
#:get-ql-dists
|
#:get-ql-dists
|
||||||
#:make-cl-info
|
#:get-cl-info
|
||||||
#:system-info
|
#:system-info
|
||||||
#:get-name
|
#:get-name
|
||||||
#:get-version
|
#:get-version
|
||||||
#:get-path
|
#:get-path
|
||||||
#:absent-p
|
#:absent-p
|
||||||
#:make-system-info))
|
#:get-system-info))
|
||||||
(in-package cl-info/core)
|
(in-package cl-info/core)
|
||||||
|
|
||||||
|
|
||||||
|
@ -30,10 +30,16 @@
|
||||||
:reader get-software-type)
|
:reader get-software-type)
|
||||||
(software-version :initform (software-version)
|
(software-version :initform (software-version)
|
||||||
:reader get-software-version)
|
:reader get-software-version)
|
||||||
|
#+quicklisp
|
||||||
(ql-dists :initform (ql-dist:all-dists)
|
(ql-dists :initform (ql-dist:all-dists)
|
||||||
:reader get-ql-dists)))
|
:reader get-ql-dists)))
|
||||||
|
|
||||||
|
|
||||||
|
#-quicklisp
|
||||||
|
(defun get-ql-dists (obj)
|
||||||
|
nil)
|
||||||
|
|
||||||
|
|
||||||
(defclass system-info ()
|
(defclass system-info ()
|
||||||
((name :initarg :name
|
((name :initarg :name
|
||||||
:reader get-name)
|
:reader get-name)
|
||||||
|
@ -51,13 +57,19 @@
|
||||||
"OS: ~A ~A
|
"OS: ~A ~A
|
||||||
Lisp: ~A ~A
|
Lisp: ~A ~A
|
||||||
ASDF: ~A
|
ASDF: ~A
|
||||||
QL: ~{~A~^~%~}
|
|
||||||
"
|
"
|
||||||
(get-software-type info)
|
(get-software-type info)
|
||||||
(get-software-version info)
|
(get-software-version info)
|
||||||
(get-lisp-type info)
|
(get-lisp-type info)
|
||||||
(get-lisp-version info)
|
(get-lisp-version info)
|
||||||
(get-asdf-version info)
|
(get-asdf-version info))
|
||||||
|
#-quicklisp
|
||||||
|
(format stream
|
||||||
|
"QL: is not available~%")
|
||||||
|
#+quicklisp
|
||||||
|
(format stream
|
||||||
|
"QL: ~{~A~^~%~}
|
||||||
|
"
|
||||||
(loop for dist in (get-ql-dists info)
|
(loop for dist in (get-ql-dists info)
|
||||||
for idx upfrom 0
|
for idx upfrom 0
|
||||||
collect (format nil "~:[~; ~]~A ~A"
|
collect (format nil "~:[~; ~]~A ~A"
|
||||||
|
@ -73,18 +85,19 @@ QL: ~{~A~^~%~}
|
||||||
(get-name info))
|
(get-name info))
|
||||||
(format stream
|
(format stream
|
||||||
"System: ~A ~A
|
"System: ~A ~A
|
||||||
~A
|
~A
|
||||||
"
|
"
|
||||||
(get-name info)
|
(get-name info)
|
||||||
(get-version info)
|
(get-version info)
|
||||||
(get-path info))))
|
(get-path info))))
|
||||||
|
|
||||||
|
|
||||||
(defun make-cl-info ()
|
(defun get-cl-info ()
|
||||||
|
"Returns information about lisp implementation, asdf and quicklisp."
|
||||||
(make-instance 'cl-info))
|
(make-instance 'cl-info))
|
||||||
|
|
||||||
|
|
||||||
(defun make-system-info (system-name)
|
(defun get-system-info (system-name)
|
||||||
(let ((system (block search-for-system
|
(let ((system (block search-for-system
|
||||||
(handler-bind ((asdf:missing-component
|
(handler-bind ((asdf:missing-component
|
||||||
(lambda (c)
|
(lambda (c)
|
||||||
|
@ -106,5 +119,3 @@ QL: ~{~A~^~%~}
|
||||||
:absent t
|
:absent t
|
||||||
:version nil
|
:version nil
|
||||||
:path nil))))
|
:path nil))))
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
"0.3.0"
|
"0.4.0"
|
Loading…
Reference in a new issue