-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathmain.lisp
113 lines (101 loc) · 4.68 KB
/
main.lisp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
;;;; Generic code to interface a Lisp script to the shell command-line.
;;;; How does it work:
;;;; We get our command line from make.
;;;; the MAIN function first initializes the environment for the system,
;;;; then processes the arguments
;;;; A key part of the argument processing is to decode the command name from
;;;; make strings to CL function names.
(in-package :asdf-tools)
(defun re (arg)
"Read-Eval function (the RE of REPL)
(the Print and Loop parts are not here)"
(eval (read-from-string arg)))
(defun find-command (name &optional earlyp)
"Given a string NAME, find the symbol for the function that implements the command, or else NIL.
Unless EARLYP is true, return NIL if the symbol is not fbound."
(block nil
(flet ((try (x)
(multiple-value-bind (sym foundp)
(find-standard-case-symbol x :asdf-tools nil)
(when (and sym (or earlyp (and foundp (fboundp sym))))
(return sym)))))
(try (strcat "%" (string name))) ;; so that you may use load, t, etc., as targets
(try name))))
(defun command-name (x &optional earlyp)
"Given a command designator as per FIND-COMMAND, return the unix-y name for it, as a string.
The UNIX-y name will be downcased, and any % prefix will be dropped."
(let ((c (find-command x earlyp)))
(when c
(let ((s (string-downcase c)))
(if (eql (first-char s) #\%) (subseq s 1) s)))))
(defun short-function-description (x)
"Short function description for x"
(when (stringp x) (setf x (find-command x)))
(if-let ((doc (and x (documentation x 'function))))
(let* ((first-line (with-input (s doc) (read-line s)))
(len (length first-line)))
(if (>= len 50) (strcat (subseq first-line 0 49) "…") first-line))))
(defun public-commands ()
;;(loop :for x :being :the :external-symbols :of :asdf-tools
;; :when (and (eq x (find-command x)) (documentation x 'function)) :collect x)
'(build-asdf build-asdf-tools doc website wc ;; build
clean %push merge-master-into-release fix-local-git-tags fix-remote-git-tags ;; git
ext-init ext-clear ext-reset ext-update ;; extension
git-all-committed-p
bump-version bump ;; version
test-load-systems test-clean-load test-basic test-ascii %load install-asdf show-version ;; test-basic
test %t test-scripts ;; test-scripts
test-upgrade u extract-tagged-asdf extract-all-tagged-asdf extract ;; test-upgrade
test-all-basic test-all-clean-load test-all-scripts test-all-no-upgrade test-all-upgrade ;; test-all
test-all test-all-scripts-no-stop test-all-upgrade-no-stop
test-all-no-upgrade-no-stop test-all-no-stop
check-all-scripts-results check-all-upgrade-results check-all-results
make-archive make-and-publish-archive publish-archive link-archive archive install ;; release
debian-package publish-debian-package
re help show-commands makefile-targets)) ;; main
(defun public-command-strings ()
(sort (mapcar 'command-name (public-commands)) 'string<))
(defun show-commands ()
"print the (sorted list of) names of all the public commands of asdf-tools."
(format t "~{~A~^ ~}~%" (public-command-strings))
(success))
(defun makefile-targets ()
"print declaration for the public commands of asdf-tools as as many Makefile targets
so that, when included in the Makefile, they will enable shell completion
based on a list of targets"
(let ((c (public-command-strings)))
(format t ".PHONY: ~{~A~^ ~}~%~%~{~A~^ ~}: force
~C${MAKE_SCRIPT} l='$l' L='$L' u='$u' U='$u' v='$v' s='$s' t='$t' $@~%" c c #\tab))
(success))
(defun help (&optional x)
"help about a command, or list of commands"
(cond
((null x)
(loop :for x :in (public-command-strings)
:do (format t "~(~27A~)~@[ ~A~]~%"
x (short-function-description x)))
(success))
(t
(let ((x (find-command x)))
(when x
(format t "~A~@[ ~A~]~%~@[~A~]~&"
(command-name x)
(or ()) ;; TODO: remember the arguments to deftestcmd, translate to v=, etc
(documentation x 'function))
(success))))))
;;; Main entry point.
;;; NB: For access control, you could check that only exported symbols are used as entry points.
(defun process-arguments (args)
(if-let ((fun (and args (find-command (first args)))))
(apply 'run-command fun (rest args))
(progn
(if args
(format t "Command ~A not found~%" (first args))
(format t "No command provided~%"))
nil)))
;;; For a multi-call binary, use these cl-launch or buildapp arguments: --dispatch-entry asdf-tools/asdf-tools::main
(defun main (argv)
(initialize-environment)
(process-arguments argv))
(defun entry-point ()
(main *command-line-arguments*))