Warning: this is an htmlized version!
The original is here, and
the conversion rules are here.
;;; eev-helpful.el -- eev support for helpful.  -*- lexical-binding: nil; -*-

;; Copyright (C) 2023 Free Software Foundation, Inc.
;;
;; This file is part of GNU eev.
;;
;; GNU eev is free software: you can redistribute it and/or modify
;; it under the terms of the GNU General Public License as published by
;; the Free Software Foundation, either version 3 of the License, or
;; (at your option) any later version.
;;
;; GNU eev is distributed in the hope that it will be useful,
;; but WITHOUT ANY WARRANTY; without even the implied warranty of
;; MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
;; GNU General Public License for more details.
;;
;; You should have received a copy of the GNU General Public License
;; along with GNU Emacs.  If not, see <http://www.gnu.org/licenses/>.
;;
;; Author:     Eduardo Ochs <[email protected]>
;; Maintainer: Eduardo Ochs <[email protected]>
;; Version:    20240305
;; Keywords:   e-scripts
;;
;; Latest version: <http://anggtwu.net/eev-current/eev-helpful.el>
;;       htmlized: <http://anggtwu.net/eev-current/eev-helpful.el.html>
;;       See also: <http://anggtwu.net/eev-current/eev-beginner.el.html>
;;                 <http://anggtwu.net/eev-intros/find-eev-intro.html>
;;                                               (find-eev-intro)


;; «.find-helpful-links»	(to "find-helpful-links")
;; «.find-hlinks»		(to "find-hlinks")
;; «.find-hkeymap-links»	(to "find-hkeymap-links")



;;; Commentary:

;; For more info on helpful, see:
;;
;;   https://github.com/Wilfred/helpful
;;   (find-epackage-links 'helpful)
;;
;; Status of this file: early alpha.
;; This code is very recent. Everything here may change.
;;
;; Note that `find-here-links' calls functions from this file
;; when the major mode is `helpful-mode' - see:
;;
;;   (find-eev "eev-hlinks.el" "hprog")
;;   (find-eev "eev-hlinks.el" "hprog" "helpful")
;;
;; Also, `find-efunction-links' and `find-evariable-links' now include
;; links with `find-hfunction' and `find-hvariable' in the temporary
;; buffers that they generate. If you execute them without having
;; helpful installed you will get errors that should be easy to
;; interpret as "hm, I need to install helpful.el"...





;;;  _                         _ _       _        
;;; | |__   ___ _ __ ___      | (_)_ __ | | _____ 
;;; | '_ \ / _ \ '__/ _ \_____| | | '_ \| |/ / __|
;;; | | | |  __/ | |  __/_____| | | | | |   <\__ \
;;; |_| |_|\___|_|  \___|     |_|_|_| |_|_|\_\___/
;;;                                               
;; «find-helpful-links»  (to ".find-helpful-links")
;; Skel: (find-find-links-links-new "helpful" "action symbol" "")
;; Test: (find-helpful-links "function" "find-file")
;;  See: (find-eevfile "eev-hlinks.el" "ee-fhl-main-program" "helpful")
;;
(defun find-helpful-links (&optional action symbol &rest pos-spec-list)
"Visit a temporary buffer containing hyperlinks to a helpful buffer."
  (interactive)
  (setq action (or action (ee-helpful-action) "{action}"))
  (setq symbol (or symbol (ee-helpful-symbol) "{symbol}"))
  (apply
   'find-elinks
   `((find-helpful-links ,action ,symbol ,@pos-spec-list)
     ;; Convention: the first sexp always regenerates the buffer.
     (find-efunction 'find-helpful-links)
     ""
     ,@(ee-find-helpful-links action symbol)
     )
   pos-spec-list))

(defun ee-find-helpful-links (&optional action symbol)
  (setq action (or action (ee-helpful-action) "{action}"))
  (setq symbol (or symbol (ee-helpful-symbol) "{symbol}"))
  (list (ee-template0 "\
# (find-h{action} '{symbol})
# (helpful-{action} '{symbol})
# (find-efunction 'helpful-{action})

# (find-efunction-links '{symbol})
# (find-evariable-links '{symbol})
")))


;; Tests: 
;; (ee-helpful-action "*helpful command: find-file*")
;; (ee-helpful-symbol "*helpful command: find-file*")
;;
(defvar ee-helpful-regexp "^\\*helpful \\([a-z]+\\): \\(.*\\)\\*$"
  "A regexp that extracts the \"action\" and the \"symbol\" from
the name of a buffer in helpful-mode.")

(defun ee-helpful-action (&optional buffername)
"An internal function used by `ee-find-helpful-links' and `find-helpful-links'."
  (setq buffername (or buffername (buffer-name)))
  (if (string-match ee-helpful-regexp buffername)
      (ee-no-properties (match-string 1 buffername))))

(defun ee-helpful-symbol (&optional buffername)
"An internal function used by `ee-find-helpful-links' and `find-helpful-links'."
  (setq buffername (or buffername (buffer-name)))
  (if (string-match ee-helpful-regexp buffername)
      (intern (ee-no-properties (match-string 2 buffername)))))



;; (load "eev-helpful.el")

;; See:


;;;  _     _       _        
;;; | |   (_)_ __ | | _____ 
;;; | |   | | '_ \| |/ / __|
;;; | |___| | | | |   <\__ \
;;; |_____|_|_| |_|_|\_\___/
;;;                         
;; «find-hlinks»  (to ".find-hlinks")
;; The functions below - with names like `find-h<action>' -
;; are hyperlinks to helpful buffers. They use this trick to
;; make helpful use the current window:
;;   (find-eev "eev-blinks.el" "find-dbsw")

;; Test: (find-hcallable 'find-file)
;;  See: (find-efunction 'helpful-callable)
(defun find-hcallable (symbol &rest pos-spec-list)
  "Run `(helpful-callable SYMBOL)' and search for POS-SPEC-LIST."
  (apply 'find-dbsw-call `(helpful-callable ',symbol) pos-spec-list))

;; Test: (find-hcommand  'find-file)
;;  See: (find-efunction 'helpful-command)
(defun find-hcommand (symbol &rest pos-spec-list)
  "Run `(helpful-command SYMBOL)' and search for POS-SPEC-LIST."
  (apply 'find-dbsw-call `(helpful-command ',symbol) pos-spec-list))

;; Test: (find-hfunction 'find-file)
;;  See: (find-efunction 'helpful-function)
(defun find-hfunction (symbol &rest pos-spec-list)
  "Run `(helpful-function SYMBOL)' and search for POS-SPEC-LIST."
  (apply 'find-dbsw-call `(helpful-function ',symbol) pos-spec-list))

;; Test: (find-hkey      (kbd "M-h M-h"))
;;  See: (find-efunction 'helpful-key)
(defun find-hkey (keyseq &rest pos-spec-list)
  "Run `(helpful-key KEYSEQ)' and search for POS-SPEC-LIST."
  (apply 'find-dbsw-call `(helpful-key ',keyseq) pos-spec-list))

;; Test: (find-hmacro    'cl-loop)
;;  See: (find-efunction 'helpful-macro)
(defun find-hmacro (symbol &rest pos-spec-list)
  "Run `(helpful-macro SYMBOL)' and search for POS-SPEC-LIST."
  (apply 'find-dbsw-call `(helpful-macro ',symbol) pos-spec-list))

;; Test: (find-hsymbol   'cl-loop)
;;  See: (find-efunction 'helpful-symbol)
(defun find-hsymbol (symbol &rest pos-spec-list)
  "Run `(helpful-symbol SYMBOL)' and search for POS-SPEC-LIST."
  (apply 'find-dbsw-call `(helpful-symbol ',symbol) pos-spec-list))

;; Test: (find-hvariable 'line-move-visual)
;;  See: (find-efunction 'helpful-variable)
(defun find-hvariable (symbol &rest pos-spec-list)
  "Run `(helpful-variable SYMBOL)' and search for POS-SPEC-LIST."
  (apply 'find-dbsw-call `(helpful-variable ',symbol) pos-spec-list))



;; «find-hkeymap-links»  (to ".find-hkeymap-links")
;; Skel: (find-find-links-links-new "hkeymap" "symbol" "ee-buffer-name")
;; Test: (find-hkeymap-links 'emacs-lisp-mode-map)
;;
(defun find-hkeymap-links (&optional symbol &rest pos-spec-list)
"Visit a temporary buffer containing hyperlinks for hkeymap."
  (interactive)
  (setq symbol (or symbol "{symbol}"))
  (let ((ee-buffer-name
	 (or ee-buffer-name
	     (format "*(find-hkeymap-links '%s)*" symbol))))
    (apply
     'find-elinks
     `((find-hkeymap-links ',symbol ,@pos-spec-list)
       ;; Convention: the first sexp always regenerates the buffer.
       (find-efunction 'find-hkeymap-links)
       ""
       (find-evariable ',symbol)
       (find-hvariable ',symbol)
       ""
       ,(helpful--format-keymap (symbol-value symbol))
       )
     pos-spec-list)))

'("--A test:--"

  (defun find-4a (a b c d) (find-wset "13_o2_o2_o_o+"  a b c d))
  (find-4a nil
    ' (find-hkeymap-links 'emacs-lisp-mode-map)
    ' (find-hkeymap-links 'lisp-mode-shared-map)
    ' (find-hkeymap-links 'prog-mode-map)
    )
  (find-4a nil
    ' (find-evariable 'emacs-lisp-mode-map)
    ' (find-evariable 'lisp-mode-shared-map)
    ' (find-evariable 'prog-mode-map)
    )

"--end--")








(provide 'eev-helpful)


;; Local Variables:
;; coding:            utf-8-unix
;; no-byte-compile:   t
;; End: