summaryrefslogtreecommitdiff
path: root/lisp/man-completion/man-completion.el
diff options
context:
space:
mode:
authorJohn Turner <jturner.usa@gmail.com>2022-10-21 22:57:24 -0400
committerJohn Turner <jturner.usa@gmail.com>2022-10-21 22:57:24 -0400
commit0feb33b83c2432b4535702fa6926a1d6cd59919d (patch)
tree5fde0e14368642e3a3ad5a14e8736d1a1f2536de /lisp/man-completion/man-completion.el
parent89818d0d1f1d1712d00839df88c16cde923c628c (diff)
downloademacs.d-0feb33b83c2432b4535702fa6926a1d6cd59919d.tar.gz
renamed man-wrapper to man-completion
Diffstat (limited to 'lisp/man-completion/man-completion.el')
-rw-r--r--lisp/man-completion/man-completion.el48
1 files changed, 48 insertions, 0 deletions
diff --git a/lisp/man-completion/man-completion.el b/lisp/man-completion/man-completion.el
new file mode 100644
index 0000000..31c5bf7
--- /dev/null
+++ b/lisp/man-completion/man-completion.el
@@ -0,0 +1,48 @@
+(defun man-completion-is-compression-suffix (suffix)
+ (string-match-p "\\.bz2$\\|gzip$\\|zst$" suffix))
+
+(defun man-completion-get-man-paths ()
+ (let* ((manpath (getenv "MANPATH"))
+ (manpaths (split-string manpath ":" t))
+ (manpaths (mapcar (lambda (path)
+ (file-expand-wildcards (file-name-concat path "man*")))
+ manpaths))
+ (manpaths (flatten-list manpaths))
+ (manpaths (seq-filter 'file-exists-p manpaths)))
+ manpaths))
+
+(defun man-completion-find-pages ()
+ (let* ((files (mapcar (lambda (p)
+ (directory-files-recursively p ".+" nil))
+ (man-completion-get-man-paths)))
+ (files (flatten-list files))
+ (files (mapcar 'file-name-base files))
+ (files (mapcar (lambda (f)
+ (if (man-completion-is-compression-suffix f)
+ (file-name-sans-extension f)
+ f))
+ files)))
+ files))
+
+(defun man-completion-locate-page (page)
+ (with-temp-buffer
+ (let ((exit-code (call-process "man" nil (current-buffer) nil "--where" page)))
+ (when exit-code
+ (let* ((output (buffer-string))
+ (trimmed (string-trim-right output "\n")))
+ trimmed)))))
+
+(defun man-completion (orig &rest args)
+ (interactive)
+ (let* ((arg (if args
+ (nth 0 args)
+ (completing-read "Select page: "
+ (man-completion-find-pages)
+ nil
+ t)))
+ (page (man-completion-locate-page arg)))
+ (funcall orig page)))
+
+(advice-add 'man :around 'man-completion)
+
+(provide 'man-completion)