Add manual support to interface, minor cleanup
author |
Steve Losh <steve@stevelosh.com> |
date |
Fri, 01 Mar 2019 14:47:30 -0500 (2019-03-01) |
parents |
b0cb724b7831
|
children |
34d2ad201c73
|
branches/tags |
(none) |
files |
README.markdown src/main.lisp |
Changes
--- a/README.markdown Mon Dec 24 00:19:26 2018 -0500
+++ b/README.markdown Fri Mar 01 14:47:30 2019 -0500
@@ -3,11 +3,8 @@
I needed **A** **D**amn **OPT**ion parsing library.
-Adopt is a simple (~150 LOC) UNIX-style option parser in Common Lisp.
-It depends on [Bobbin][] and [split-sequence][].
-
-The test suite currently passes in SBCL, CCL, ECL, and ABCL on Ubuntu. Further
-testing is welcome.
+Adopt is a simple UNIX-style option parser in Common Lisp. It depends on
+[Bobbin][] and [split-sequence][].
* **License:** MIT
* **Documentation:** <https://sjl.bitbucket.io/adopt/>
--- a/src/main.lisp Mon Dec 24 00:19:26 2018 -0500
+++ b/src/main.lisp Fri Mar 01 14:47:30 2019 -0500
@@ -146,7 +146,8 @@
(short-options :initarg :short-options :accessor short-options)
(long-options :initarg :long-options :accessor long-options)
(usage :initarg :usage :accessor usage)
- (documentation :initarg :documentation :accessor documentation)))
+ (documentation :initarg :documentation :accessor documentation)
+ (manual :initarg :manual :accessor manual)))
(defmethod print-object ((i interface) stream)
(print-unreadable-object (i stream :type t)
@@ -158,13 +159,14 @@
(long o)))
(options i)))))
-(defun make-interface (&key name summary usage documentation examples options)
+(defun make-interface (&key name summary usage documentation manual examples options)
(let ((interface (make-instance 'interface
:options nil
:name name
:usage usage
:summary summary
:documentation documentation
+ :manual manual
:examples examples
:short-options (make-hash-table)
:long-options (make-hash-table :test #'equal))))
@@ -189,13 +191,14 @@
name)))
(defmacro define-interface
- (symbol (&key name summary usage documentation examples) &body options)
+ (symbol (&key name summary usage documentation manual examples) &body options)
`(defparameter ,symbol
(make-interface
:name ,name
:summary ,summary
:usage ,usage
:documentation ,documentation
+ :manual ,manual
:examples ,examples
:options
(list
@@ -326,7 +329,7 @@
1. A fresh list of top-level, unaccounted-for arguments that don't correspond
to any options defined in `interface`.
- 2. An `EQL` hash table of option `name`s to values.
+ 2. An `EQL` hash table of option keys to values.
See the full usage documentation for more information.
@@ -513,7 +516,7 @@
"
(format stream "~A~A~%" (or prefix "") error)
- (adopt:exit exit-code))
+ (exit exit-code))
;;;; Man ----------------------------------------------------------------------
@@ -578,7 +581,8 @@
(f ".R ~A" (escape (usage interface)))))
(print-description ()
(f ".SH DESCRIPTION")
- (fa (split-paragraphs (documentation interface))))
+ (fa (split-paragraphs (or (manual interface)
+ (documentation interface)))))
(print-option (option)
(f ".TP")
(fa (option-troff option))