summaryrefslogtreecommitdiffstats
path: root/stdlib
diff options
context:
space:
mode:
authorKaz Kylheku <kaz@kylheku.com>2022-02-03 23:16:23 -0800
committerKaz Kylheku <kaz@kylheku.com>2022-02-03 23:16:23 -0800
commitf4c54fbad69d1181057fe5025f537802b9eec610 (patch)
tree0f932e4c51fd2436f931ba6de04d2526c27635ef /stdlib
parent55dca8cda3825e0f338584ff853a8fc78b98b328 (diff)
downloadtxr-f4c54fbad69d1181057fe5025f537802b9eec610.tar.gz
txr-f4c54fbad69d1181057fe5025f537802b9eec610.tar.bz2
txr-f4c54fbad69d1181057fe5025f537802b9eec610.zip
getopts: break up help into three functions.
* lisplib.c (getopts_set_entries): Autoload for opthelp-conventions and opthelp-types. * stdlib/getopts.tl (opthelp): Remove incnotes parameter. Entirely trim out the code for notes about conventions and use of types. (opthel-conventions, opthelp-types): New functions. (option-base opthelp-conventions, option-base opthelp-types): New methods. * txr.1: Documented. * stdlib/doc-syms.tl: Updated.
Diffstat (limited to 'stdlib')
-rw-r--r--stdlib/doc-syms.tl4
-rw-r--r--stdlib/getopts.tl148
2 files changed, 81 insertions, 71 deletions
diff --git a/stdlib/doc-syms.tl b/stdlib/doc-syms.tl
index 71302389..a296a126 100644
--- a/stdlib/doc-syms.tl
+++ b/stdlib/doc-syms.tl
@@ -1397,7 +1397,9 @@
("opost" "N-03BD477F")
("opt" "N-0047F5AB")
("opt-desc" "N-03FC5092")
- ("opthelp" "N-016C6171")
+ ("opthelp" "N-010286EC")
+ ("opthelp-conventions" "N-010286EC")
+ ("opthelp-types" "N-010286EC")
("opts" "N-01D911E8")
("or" "D-001A")
("orec" "N-0003ED2C")
diff --git a/stdlib/getopts.tl b/stdlib/getopts.tl
index 65b6e4dc..70413902 100644
--- a/stdlib/getopts.tl
+++ b/stdlib/getopts.tl
@@ -269,7 +269,7 @@
(opr (new sys:opt-processor od-list opt-desc-list opts opts)))
opr.(parse-opts args)))
-(defun opthelp (opt-desc-list : (stream *stdout*) (incnotes t))
+(defun opthelp (opt-desc-list : (stream *stdout*))
(let ((sorted [nsort (copy-list (remove-if (op null @1.helptext)
opt-desc-list)) :
(do if @1.long @1.long @1.short)])
@@ -306,74 +306,78 @@
(flatten (mappend (op list @1.short @1.long)
undocumented))] ", "}`))
(each ((line (sys:wdwrap undoc-str 75)))
- (put-line ` @line` stream)))
- (put-line : stream))
- (when incnotes
- (put-line "Notes:\n" stream)
- (let* ((have-short (some sorted (usl short)))
- (have-long (some sorted (usl long)))
- (have-arg-p (some sorted (usl arg-p)))
- (have-bool (some sorted (op eq @1.type :bool)))
- (texts (list (if have-short
- "Short options can be invoked with long syntax: \ \
- for example, --a can be used when -a exists.\ \
- Short no-argument options can be clumped into\ \
- one argument as exemplified by -xyz.")
- (if have-bool
- (if have-arg-p
- "Options that take no argument are Boolean:"
- (if undocumented
- "All documented options are Boolean:"
- "All options are Boolean:")))
- (if have-bool
- "they are true when present, false when absent.")
- (if (and have-bool have-arg-p)
- "The --no- prefix can explicitly specify \ \
- Boolean options as false: if a Boolean option\ \
- X exists,\ \
- --no-X specifies it as false. This is useful\ \
- for making false those options which default\ \
- to true. "
- "The --no- prefix can explicitly specify \ \
- options as false: if an X option exists,\ \
- --no-X specifies it as false. This is useful\ \
- for making false those options which default\ \
- to true. ")
- (if (not have-long)
- "Note the double dash on --no.")
- (if (and have-short have-long)
- "The --no- prefix can be applied to a short\ \
- or long option name.")
+ (put-line ` @line` stream))))))
+
+(defun opthelp-conventions (opt-desc-list : (stream *stdout*))
+ (let ((documented (remove-if (op null @1.helptext) opt-desc-list))
+ (undocumented (keep-if (op null @1.helptext) opt-desc-list)))
+ (put-line "Option Conventions:\n" stream)
+ (let* ((have-short (some documented (usl short)))
+ (have-long (some documented (usl long)))
+ (have-arg-p (some documented (usl arg-p)))
+ (have-bool (some documented (op eq @1.type :bool)))
+ (texts (list (if have-short
+ "Short options can be invoked with long syntax: \ \
+ for example, --a can be used when -a exists.\ \
+ Short no-argument options can be clumped into\ \
+ one argument as exemplified by -xyz.")
+ (if have-bool
(if have-arg-p
- "The argument to a long option can be given in one\ \
- argument as --option=arg or as a separate\ \
- argument using --option arg.")
- "The special argument -- can be used where an option\ \
- may appear. It means \"end of options\": the\ \
- arguments which follow are not treated as options\ \
- even if they look like options.")))
- (mapdo (do put-line ` @1` stream)
- (sys:wdwrap `@{(flatten texts)}` 77)))
- (put-line : stream)
- (whenlet ((types (keep-if [andf keywordp (op neq :bool)]
- (uniq (mapcar (usl type) sorted)))))
- (put-line "Type legend:\n" stream)
- (each ((ty types))
- (iflet ((ln (caseql ty
- (:dec " DEC - Decimal integer: -123, 0, 5, +73")
- (:hex " HEX - Hexadecimal integer -EF, 2D0, +9A")
- (:oct " OCT - Octal integer: -773, 5677, +326")
- (:cint " CINT - C-style integer: leading 0 octal,\
- \ leading 0x hex, else decimal;\n\
- \ leading sign allowed: -0777, 0xFDC, +123")
- (:float " FLOAT - Floating-point: -1.3e+03, +5, 3.3,\
- \ 3., .5, .12e9, 53.e-3, 3e-015")
- (:str " STR - String with embedded escapes, valid\
- \ as TXR Lisp string literals\n\
- \ syntax: foo, foo\\tbar, abc\\nxyz")
- (:text " TEXT - Unprocessed text"))))
- (put-line ln stream)))
- (put-line : stream)))))
+ "Options that take no argument are Boolean:"
+ (if undocumented
+ "All documented options are Boolean:"
+ "All options are Boolean:")))
+ (if have-bool
+ "they are true when present, false when absent.")
+ (if (and have-bool have-arg-p)
+ "The --no- prefix can explicitly specify \ \
+ Boolean options as false: if a Boolean option\ \
+ X exists,\ \
+ --no-X specifies it as false. This is useful\ \
+ for making false those options which default\ \
+ to true. "
+ "The --no- prefix can explicitly specify \ \
+ options as false: if an X option exists,\ \
+ --no-X specifies it as false. This is useful\ \
+ for making false those options which default\ \
+ to true. ")
+ (if (not have-long)
+ "Note the double dash on --no.")
+ (if (and have-short have-long)
+ "The --no- prefix can be applied to a short\ \
+ or long option name.")
+ (if have-arg-p
+ "The argument to a long option can be given in one\ \
+ argument as --option=arg or as a separate\ \
+ argument using --option arg.")
+ "The special argument -- can be used where an option\ \
+ may appear. It means \"end of options\": the\ \
+ arguments which follow are not treated as options\ \
+ even if they look like options.")))
+ (mapdo (do put-line ` @1` stream)
+ (sys:wdwrap `@{(flatten texts)}` 77)))))
+
+(defun opthelp-types (opt-desc-list : (stream *stdout*))
+ (let ((documented (remove-if (op null @1.helptext) opt-desc-list)))
+ (whenlet ((types (keep-if [andf keywordp (op neq :bool)]
+ (uniq (mapcar (usl type) documented)))))
+ (put-line "Type legend:\n" stream)
+ (each ((ty types))
+ (iflet ((ln (caseql ty
+ (:dec " DEC - Decimal integer: -123, 0, 5, +73")
+ (:hex " HEX - Hexadecimal integer -EF, 2D0, +9A")
+ (:oct " OCT - Octal integer: -773, 5677, +326")
+ (:cint " CINT - C-style integer: leading 0 octal,\
+ \ leading 0x hex, else decimal;\n\
+ \ leading sign allowed: -0777, 0xFDC, +123")
+ (:float " FLOAT - Floating-point: -1.3e+03, +5, 3.3,\
+ \ 3., .5, .12e9, 53.e-3, 3e-015")
+ (:str " STR - String with embedded escapes, valid\
+ \ as TXR Lisp string literals\n\
+ \ syntax: foo, foo\\tbar, abc\\nxyz")
+ (:text " TEXT - Unprocessed text"))))
+ (put-line ln stream)))
+ (put-line : stream))))
(defstruct sys:option-base nil
in-args
@@ -390,8 +394,12 @@
(set me.in-args args me.out-args args)
(let ((opr (new sys:opt-processor od-list me.opt-desc-list opts me)))
opr.(parse-opts args)))
- (:method opthelp (me : (stream *stdout*) (incnotes t))
- (opthelp me.opt-desc-list stream incnotes)))
+ (:method opthelp (me : (stream *stdout*))
+ (opthelp me.opt-desc-list stream))
+ (:method opthelp-conventions (me : (stream *stdout*))
+ (opthelp-conventions me.opt-desc-list stream))
+ (:method opthelp-types (me : (stream *stdout*))
+ (opthelp-types me.opt-desc-list stream)))
(defmacro define-option-struct (name super-spec . opts)
(let* ((slots (mapcar (tb ((short long . rest))