emacs-elpa-diffs
[Top][All Lists]
Advanced

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[elpa] externals/hyperbole a535696bb4 08/14: Support latest Treemacs and


From: ELPA Syncer
Subject: [elpa] externals/hyperbole a535696bb4 08/14: Support latest Treemacs and HyWiki page navigation with it
Date: Mon, 11 Nov 2024 03:58:24 -0500 (EST)

branch: externals/hyperbole
commit a535696bb43ce3d876ba8167ebc961357883f99a
Author: bw <rsw@gnu.org>
Commit: bw <rsw@gnu.org>

    Support latest Treemacs and HyWiki page navigation with it
    
    Add HyWiki improvements to the Hyperbole manual.
---
 ChangeLog          |  74 +++++++++++++++++++++++++++++++-
 hui-jmenu.el       |   7 +++-
 hui-treemacs.el    |  91 +++++++++++++++++++++++-----------------
 hui-window.el      | 121 ++++++++++++++++++++++++++++++++++++++++++++++-------
 hui.el             |   5 ++-
 hycontrol.el       |  37 ++++++++--------
 hyperbole.el       |   7 +++-
 hywiki.el          |  36 +++++++++++++---
 man/hkey-help.txt  |   2 +-
 man/hyperbole.info | Bin 661556 -> 663085 bytes
 man/hyperbole.texi | 110 ++++++++++++++++++++++++++++++------------------
 11 files changed, 365 insertions(+), 125 deletions(-)

diff --git a/ChangeLog b/ChangeLog
index 2899e1dd74..2241258e71 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -1,3 +1,75 @@
+2024-11-10  Bob Weiner  <rsw@gnu.org>
+
+* hui-window.el (action-key-modeline-left-edge-function,
+                 action-key-modeline-left-edge-function,
+                 assist-key-modeline-left-edge-function,
+                 action-key-modeline-right-edge-function): Add these
+    customizations.
+                (action-key-modeline-click-left-edge,
+                 assist-key-modeline-click-left-edge,
+                 action-key-modeline-click-right-edge,
+                 assist-key-modeline-click-right-edge): Add these functions
+    as defaults for the above customizations.
+                (hmouse-modeline-default-help-echo): Replacement for default
+    'mode-line-default-help-echo' function that produces mode line hover doc
+    for the Smart Mouse Keys.
+  hyperbole.el (hyperbole--enable-mode): Update mode-line hover doc in blank
+    areas for button-2 and button-3 if using unshifted Smart Keys.
+
+* hui-jmenu.el (hui-menu-modeline): Add HyWiki-Edit-Pages to display a list
+    of HyWiki page files either in dired or Treemacs.
+
+* hui-treemacs.el (require): Prompt to install package if not yet installed.
+
+* hui-window.el (hmouse-horizontal-assist-drag): Fix doc when one window only.
+
+* man/hyperbole.texi (HyWiki Menu): Add index entries per menu item.
+
+* hywiki.el (hywiki-directory-edit): Rename to 'hywiki-directory-dired-edit'.
+            (hywiki-directory-edit): Make a new version that supports
+    'treemacs' when 'action-key-modeline-buffer-id-function' is set to
+    'smart-treemacs-modeline.
+
+* hui-treemacs.el (smart-treemacs): Simplify and no longer call
+    'treemacs-node-buffer-and-position' which can trigger a marker error.
+                  (smart-treemacs-edit): Add to edit/display a dir in Treemacs.
+                  (smart-treemacs-modeline): Call above function.
+  hywiki.el (hywiki-directory-treemacs-edit): Add and call above function.
+
+* hycontrol.el (hycontrol-window-display-buffer): Fix to ignore any dedicated
+    windows and prevent an error typically generated when calling this from
+    'walk-windows' called within 'hycontrol-windows-grid'.  Makes window grids
+    work with Treemacs display, for example.
+
+* hui-treemacs.el (smart-treemacs): Fix invocation of TAB command on first line
+    entry (treat it like any other line except at eol).  Also, actually invoke
+    latest treemacs TAB command when defined rather that calling the default
+    command normally configured to the TAB key.  Ensure all func calls are
+    wrapped with 'hact'.
+                  (smart-treemacs-modeline): Ensure always displays just the
+    dir associated with the current buffer.  Wrap all func calls with 'hact'.
+  man/hyperbole.texi (Smart Key - Treemacs): Update doc to match above change.
+                  (smart-treemacs-quit): Add to ensure treemacs-quit is run
+    within the Treemacs window.
+
+* hywiki.el (hywiki-directory-edit): Support non-bash shells that cannot handle
+    character classes.
+
+2024-11-03  Bob Weiner  <rsw@gnu.org>
+
+* hywiki.el (hywiki-maybe-highlight-page-name, 
hywiki-maybe-dehighlight-page-name):
+    Change to use function (hywiki-get-buttonize-characters) rather than the
+    variable, hywiki--buttonize-characters, so do not move back over whitespace
+    when at the beginning of a HyWikiWord.
+
+* hyrolo.el (hyrolo-grep-file): Don't set grepped file to read-only since
+    this can later make org-capture fail.  (gh#rswgnu/hyperbole/599)
+
+2024-11-02  Bob Weiner  <rsw@gnu.org>
+
+* man/hyperbole.texi: Change all @url to @uref so display properly in
+    Info-format output.
+
 2024-10-28  Bob Weiner  <rsw@gnu.org>
 
 * hibtypes.el (hywiki-existing-word): Call action with the singular version
@@ -14,7 +86,7 @@
     an infinite loop.
             (hywiki-add-page, hywiki-make-pages-hasht): Reset
     'hywiki--any-page-regexp-list' whenever hasht is rebuilt.  Otherwise,
-    highlihgting might not include new wikiwords in hasht.
+    highlighting might not include new wikiwords in hasht.
 
 2024-10-27  Bob Weiner  <rsw@gnu.org>
 
diff --git a/hui-jmenu.el b/hui-jmenu.el
index 32033fe7c0..4939f36eaf 100644
--- a/hui-jmenu.el
+++ b/hui-jmenu.el
@@ -3,7 +3,7 @@
 ;; Author:       Bob Weiner
 ;;
 ;; Orig-Date:     9-Mar-94 at 23:37:28
-;; Last-Mod:     19-Jan-24 at 14:09:51 by Mats Lidell
+;; Last-Mod:     11-Nov-24 at 00:35:43 by Bob Weiner
 ;;
 ;; SPDX-License-Identifier: GPL-3.0-or-later
 ;;
@@ -111,7 +111,8 @@
 
 ;;;###autoload
 (defun hui-menu-screen-commands ()
-  "Popup a menu of buffers, frames, and windows, allowing user to jump to one."
+  "Popup a menu of screen control and jump to menus.
+Jump to: HyWiki pages, buffers, frames, and windows."
   (interactive)
   (popup-menu '("Hyperbole Screen Commands" :filter hui-menu-modeline)))
 
@@ -177,6 +178,8 @@ Jump to chosen buffer."
 (defun hui-menu-modeline (_ignore)
   "Return a modeline menu."
   (list
+   ["HyWiki-Edit-Pages"  hywiki-directory-edit t]
+   "----"
    ["Control-Frames"  hycontrol-enable-frames-mode t]
    ["Control-Windows" hycontrol-enable-windows-mode t]
    "----"
diff --git a/hui-treemacs.el b/hui-treemacs.el
index 5ff20df418..35ca206d4b 100644
--- a/hui-treemacs.el
+++ b/hui-treemacs.el
@@ -3,7 +3,7 @@
 ;; Author:       Bob Weiner
 ;;
 ;; Orig-Date:    19-Nov-17
-;; Last-Mod:     20-Jan-24 at 20:20:00 by Mats Lidell
+;; Last-Mod:     10-Nov-24 at 17:27:30 by Bob Weiner
 ;;
 ;; SPDX-License-Identifier: GPL-3.0-or-later
 ;;
@@ -26,7 +26,8 @@
 
 (or (require 'treemacs nil t)
     (and (package-installed-p 'treemacs)
-        (package-activate 'treemacs)))
+        (package-activate 'treemacs))
+    (hypb:require-package 'treemacs))
 
 (defvar treemacs-version)
 
@@ -39,10 +40,10 @@
 (declare-function treemacs "ext:treemacs")
 (declare-function treemacs-current-button "ext:treemacs-core-utils")
 (declare-function treemacs-current-visibility "ext:treemacs-scope")
-(declare-function treemacs-get-local-buffer "ext:treemacs-scope")
+(declare-function treemacs-get-local-window "ext:treemacs-scope")
 (declare-function treemacs-is-treemacs-window? "ext:treemacs-core-utils")
-(declare-function treemacs-node-buffer-and-position 
"etx:treemacs-mouse-interface")
-(declare-function treemacs-quit "ext:treemacs-core-utils")
+(declare-function treemacs-node-buffer-and-position 
"ext:treemacs-mouse-interface")
+(declare-function treemacs-quit "ext:treemacs-interface")
 (declare-function treemacs-toggle-node "ext:treemacs-interface")
 (defvar aw-ignored-buffers)
 
@@ -68,6 +69,25 @@
 (unless (fboundp 'treemacs-quit)
   (fset 'treemacs-quit #'bury-buffer))
 
+;;;###autoload
+(defun smart-treemacs-edit (&optional dir)
+  "Use `treemacs' to edit optional DIR or the `default-directory'."
+  (let ((default-directory (if (stringp dir) dir default-directory)))
+    (cond ((fboundp #'treemacs-add-and-display-current-project-exclusively)
+          (treemacs-add-and-display-current-project-exclusively))
+         ;; Older obsoleted function
+         ((fboundp #'treemacs-display-current-project-exclusively)
+          (treemacs-display-current-project-exclusively))
+         (t (treemacs)))))
+
+(defun smart-treemacs-quit (&optional arg)
+  "Quit treemacs visible in current frame with `bury-buffer'.
+With a prefix ARG call `treemacs-kill-buffer' instead."
+  (interactive "P")
+  (when (eq (treemacs-current-visibility) 'visible)
+    (with-selected-window (treemacs-get-local-window)
+      (treemacs-quit arg))))
+
 ;;;###autoload
 (defun smart-treemacs ()
   "Use a single key or mouse key to manipulate directory entries.
@@ -77,37 +97,28 @@ caller has already checked that the key was pressed in an 
appropriate buffer
 and has moved the cursor there.
 
 If key is pressed:
- (1) on an entry icon, the treemacs TAB command is run to expand and
-     collapse the entry;
- (2) elsewhere within an entry line, the item is displayed for editing,
-     normally in another window;
- (3) at the end of an entry line: invoke `action-key-eol-function',
-     typically to scroll up proportionally, if an Action Key press; invoke
-     `assist-key-eol-function', typically to scroll down proportionally,
-     if an Asisst Key press;
- (4) on the first line of the buffer (other than the end of line),
-     Dired is run on the current directory of this Treemacs;
- (5) at the end of the first or last line of the buffer,
-     this Treemacs invocation is quit."
+ (1) on or to the left of an entry icon, run the treemacs TAB command
+     to expand or collapse the entry;
+ (2) elsewhere within an entry line, display the item, which may be a
+     directory, for editing, normally in another window;
+ (3) at the end of an entry line: if an Action Key press, invoke
+     `action-key-eol-function', typically to scroll up proportionally;
+     if an Asisst Key press, invoke `assist-key-eol-function', typically
+     to scroll down proportionally;
+ (4) at the end of the first or last line of the buffer, quit this
+     Treemacs invocation."
 
   (interactive)
-  (cond ((first-line-p)
-        (if (eolp)
-            (treemacs-quit)
-          (hact 'link-to-directory default-directory)))
-       ((and (last-line-p) (eolp))
-        (treemacs-quit))
+  (cond ((and (eolp) (or (first-line-p) (last-line-p)))
+        (hact 'smart-treemacs-quit))
        ((eolp)
-        (funcall (if assist-flag assist-key-eol-function 
action-key-eol-function)))
-       (t (let ((over-icon (and (treemacs-current-button)
-                                (= (point) (- (button-start 
(treemacs-current-button)) 2))))
-                (result (treemacs-node-buffer-and-position)))
-            (if (and (not over-icon) result (or (bufferp result) (listp 
result)))
-                (if (listp result)
-                    (hact 'link-to-buffer-tmp (seq-elt result 0) (seq-elt 
result 1))
-                  ;; (bufferp result)
-                  (hact 'link-to-buffer-tmp result))
-              (treemacs-toggle-node current-prefix-arg))))))
+        (hact 'funcall (if assist-flag assist-key-eol-function 
action-key-eol-function)))
+       (t (if (and (treemacs-current-button)
+                   (= (point) (- (button-start (treemacs-current-button)) 2)))
+              ;; Before or on the entry's icon
+              (hact 'treemacs-TAB-action current-prefix-arg)
+            ;; On the entry, handles dirs, files and tag entries
+            (hact 'treemacs-RET-action current-prefix-arg)))))
 
 ;;;###autoload
 (defun smart-treemacs-modeline ()
@@ -123,21 +134,23 @@ Suitable for use as a value of 
`action-key-modeline-buffer-id-function'."
    ;; Clicked on Treemacs buffer id
    ((if action-key-depress-window
        (treemacs-is-treemacs-window? action-key-depress-window)
-      (string-match " Treemacs " (format-mode-line mode-line-format)))
+      (hact 'string-match " Treemacs " (format-mode-line mode-line-format)))
     ;; Quit/hide treemacs.
-    (treemacs-quit))
+    (hact 'treemacs-quit))
    ;;
    ;; Treemacs is visible and displaying the same dir as
    ;; the default dir of the clicked on modeline.
    ((and (eq (treemacs-current-visibility) 'visible)
         (string-equal (expand-file-name default-directory)
-                      (with-current-buffer (treemacs-get-local-buffer)
-                        default-directory)))
+                      (with-selected-window (treemacs-get-local-window)
+                        (save-excursion
+                          (goto-char (point-min))
+                          default-directory))))
     ;; Quit/hide treemacs.
-    (treemacs-quit))
+    (hact 'smart-treemacs-quit))
    ;;
    ;; Otherwise, invoke treemacs on the default dir of the clicked on modeline.
-   (t (treemacs))))
+   (t (hact 'smart-treemacs-edit))))
 
 (provide 'hui-treemacs)
 ;;; hui-treemacs.el ends here
diff --git a/hui-window.el b/hui-window.el
index 5cf2965f19..71bd190756 100644
--- a/hui-window.el
+++ b/hui-window.el
@@ -3,7 +3,7 @@
 ;; Author:       Bob Weiner
 ;;
 ;; Orig-Date:    21-Sep-92
-;; Last-Mod:     21-Jan-24 at 10:32:38 by Bob Weiner
+;; Last-Mod:     11-Nov-24 at 00:20:41 by Bob Weiner
 ;;
 ;; SPDX-License-Identifier: GPL-3.0-or-later
 ;;
@@ -94,6 +94,30 @@ of screen control commands."
   :type 'function
   :group 'hyperbole-keys)
 
+(defcustom action-key-modeline-left-edge-function 
#'action-key-modeline-click-left-edge
+  "*Function run on an Action Mouse Key click at a modeline left edge.
+To disable it, set it to #\\='ignore."
+  :type 'function
+  :group 'hyperbole-keys)
+
+(defcustom assist-key-modeline-left-edge-function 
#'assist-key-modeline-click-left-edge
+  "*Function run on an Assist Mouse Key click at a modeline left edge.
+To disable it, set it to #\\='ignore."
+  :type 'function
+  :group 'hyperbole-keys)
+
+(defcustom action-key-modeline-right-edge-function 
#'action-key-modeline-click-right-edge
+  "*Function run on an Action Mouse Key click at a modeline right edge.
+To disable it, set it to #\\='ignore."
+  :type 'function
+  :group 'hyperbole-keys)
+
+(defcustom assist-key-modeline-right-edge-function 
#'assist-key-modeline-click-right-edge
+  "*Function run on an Assist Mouse Key click at a modeline right edge.
+To disable it, set it to #\\='ignore."
+  :type 'function
+  :group 'hyperbole-keys)
+
 (defun hmouse-map-modes-to-form (mode-forms)
   "Map over MODE-FORMS, a sequence of (major-mode(s) form-to-eval) lists.
 Return items with a single `major-mode' in the car, (major-mode form-to-eval)."
@@ -273,6 +297,28 @@ and release to register a diagonal drag.")
 ;;; Public functions
 ;;; ************************************************************************
 
+(defalias 'action-key-modeline-click-left-edge 'bury-buffer
+  "Default function run on an Action Mouse Key click at a modeline left edge.")
+
+(defun assist-key-modeline-click-left-edge ()
+  "Default function run on an Assist Mouse Key click at a modeline left edge."
+  (if (fboundp 'last)
+      (switch-to-buffer (car (last (buffer-list))))
+    (let ((buffers (buffer-list)))
+      (switch-to-buffer (nth (1- (length buffers)) buffers)))))
+
+(defun action-key-modeline-click-right-edge ()
+  "Default function run on an Action Mouse Key click at a modeline right edge."
+  (if (eq major-mode 'Info-mode)
+      (quit-window)
+    (info)))
+
+(defun assist-key-modeline-click-right-edge ()
+  "Default function run on an Assist Mouse Key click at a modeline right edge."
+  (if (string-match "Hyperbole Smart Keys" (buffer-name))
+      (hkey-help-hide)
+    (hkey-summarize 'current-window)))
+
 (defun hmouse-at-item-p (start-window)
   "Return t if point is on an item draggable by Hyperbole, otherwise nil.
 Draggable items include Hyperbole buttons, Dired items, buffer/ibuffer
@@ -687,6 +733,58 @@ If free variable `assist-flag' is non-nil, uses Assist 
Key."
                (<= (abs (- last-press-x right-side-ln))
                    hmouse-side-sensitivity))))))
 
+;; Derived from bindings.el
+(defun hmouse-modeline-default-help-echo (window)
+  "Return default help echo text for WINDOW's mode line."
+  (let* ((frame (window-frame window))
+         (line-1a
+          ;; Show text to select window only if the window is not
+          ;; selected.
+          (not (eq window (frame-selected-window frame))))
+         (line-1b
+          ;; Show text to drag mode line if either the window is not
+          ;; at the bottom of its frame or the minibuffer window of
+          ;; this frame can be resized.  This matches a corresponding
+          ;; check in `mouse-drag-mode-line'.
+          (or (not (window-at-side-p window 'bottom))
+              (let ((mini-window (minibuffer-window frame)))
+                (and (eq frame (window-frame mini-window))
+                     (or (minibuffer-window-active-p mini-window)
+                         (not resize-mini-windows))))))
+         (line-2a
+         (and (boundp 'hyperbole-mode) hyperbole-mode))
+         (line-2b
+          ;; Show text make window occupy the whole frame
+          ;; only if it doesn't already do that.
+          (not (eq window (frame-root-window frame))))
+         (line-3
+          ;; Show text to delete window only if that's possible.
+          (not (eq window (frame-root-window frame)))))
+    (when (or line-1a line-1b line-2a line-2b line-3)
+      (concat
+       (when (or line-1a line-1b)
+         (concat
+          "mouse-1: "
+         (when line-2a "           ")
+          (when line-1a "Select window")
+          (when line-1b
+            (if line-1a " (drag to resize)" "Drag to resize"))
+          (when (or line-2a line-2b line-3) "\n")))
+       (cond (line-2a
+             (concat
+               "mouse-2:            Show/hide buffer menu\n"
+               "mouse-2 right edge: Show/hide Info manuals buffer\n"))
+            (line-2b
+              (concat
+               "mouse-2: Make window occupy whole frame"
+               (when line-3 "\n"))))
+       (cond (line-2a
+             (concat
+               "mouse-3:            Screen Control and Jump Menus\n"
+               "mouse-3 right edge: Show/hide Action/Assist Key actions"))
+            (line-3
+              "mouse-3: Remove window from frame"))))))
+
 (defun hmouse-read-only-toggle-key ()
   "Return the first toggle read-only mode key binding, or nil if none."
   (key-description (where-is-internal #'read-only-mode nil t)))
@@ -723,7 +821,7 @@ Beep and print message if the window cannot be split 
further."
 
 (defun hmouse-horizontal-assist-drag ()
   "Handle an Assist Key horizontal drag within a window: delete the current 
window.
-Beep and print message if the window cannot be split further."
+Beep and print message if the sole window which cannot be deleted."
   (condition-case ()
       (delete-window)
     (error (beep)
@@ -975,11 +1073,10 @@ If the Action Key is:
     (when (hmouse-modeline-click)
       (cond ((hmouse-emacs-at-modeline-buffer-id-p)
             (funcall action-key-modeline-buffer-id-function))
-           ((hmouse-release-left-edge) (bury-buffer))
+           ((hmouse-release-left-edge)
+            (funcall action-key-modeline-left-edge-function))
            ((hmouse-release-right-edge)
-            (if (eq major-mode 'Info-mode)
-                (quit-window)
-              (info)))
+            (funcall action-key-modeline-right-edge-function))
            (t (funcall action-key-modeline-function))))))
 
 (defun assist-key-modeline ()
@@ -1004,21 +1101,15 @@ If the Assist Key is:
   ;; Modeline window resizing is now handled in assist-key-depress
   ;; via a call to mouse-drag-mode-line, providing live visual
   ;; feedback.
-  (let ((buffers)
-       (w (smart-window-of-coords assist-key-depress-args)))
+  (let ((w (smart-window-of-coords assist-key-depress-args)))
     (when w (select-window w))
     (when (hmouse-modeline-click)
           (cond ((hmouse-emacs-at-modeline-buffer-id-p)
                  (next-buffer))
                 ((hmouse-release-left-edge)
-                 (if (fboundp 'last)
-                     (switch-to-buffer (car (last (buffer-list))))
-                   (setq buffers (buffer-list))
-                   (switch-to-buffer (nth (1- (length buffers)) buffers))))
+                 (funcall assist-key-modeline-left-edge-function))
                 ((hmouse-release-right-edge)
-                 (if (string-match "Hyperbole Smart Keys" (buffer-name))
-                     (hkey-help-hide)
-                   (hkey-summarize 'current-window)))
+                 (funcall assist-key-modeline-right-edge-function))
                 (t (funcall assist-key-modeline-function))))))
 
 (defun hmouse-drag-p ()
diff --git a/hui.el b/hui.el
index f397537d26..3d064a6760 100644
--- a/hui.el
+++ b/hui.el
@@ -3,7 +3,7 @@
 ;; Author:       Bob Weiner
 ;;
 ;; Orig-Date:    19-Sep-91 at 21:42:03
-;; Last-Mod:     29-Aug-24 at 17:08:21 by Bob Weiner
+;; Last-Mod:     10-Nov-24 at 15:44:56 by Bob Weiner
 ;;
 ;; SPDX-License-Identifier: GPL-3.0-or-later
 ;;
@@ -127,7 +127,8 @@ point; see `hui:delimited-selectable-thing'."
               (indicate-copied-region)))))))
 
 ;; Override the {M-w} command from "simple.el" when hyperbole-mode is active
-;; to allow copying kcell references or regions.
+;; to allow copying kcell references, active regions and delimited
+;; areas (like sexpressions).
 ;;;###autoload
 (defun hui-kill-ring-save (beg end &optional region)
   "Save the active region as if killed, but don't kill it.
diff --git a/hycontrol.el b/hycontrol.el
index 46bcec75ae..581aedcbb4 100644
--- a/hycontrol.el
+++ b/hycontrol.el
@@ -3,7 +3,7 @@
 ;; Author:       Bob Weiner
 ;;
 ;; Orig-Date:     1-Jun-16 at 15:35:36
-;; Last-Mod:     16-Sep-24 at 22:40:19 by Bob Weiner
+;; Last-Mod:     10-Nov-24 at 14:57:49 by Bob Weiner
 ;;
 ;; SPDX-License-Identifier: GPL-3.0-or-later
 ;;
@@ -905,7 +905,9 @@ Used after selected buffer list is exhausted.")
 
 (defun hycontrol-window-display-buffer (window)
   "Given a WINDOW, choose the next appropriate buffer to display.
-Uses `hycontrol--buffer-list'.
+If WINDOW is dedicated, ignore it and do nothing.
+
+Uses hycontrol--buffer-list'.
 
 When `hycontrol--invert-display-buffer-predicates' is non-nil and not
 \\='ignore, the list of buffers used is further filtered using the
@@ -915,21 +917,22 @@ files.
 
 Filtering is disabled if a specific list of buffers is sent to the
 `hycontrol-make-windows-grid' function that calls this."
-  (let ((buf (car hycontrol--buffer-list-pointer)))
-    (setq hycontrol--buffer-list-pointer (cdr hycontrol--buffer-list-pointer))
-    (while (and buf (or (= (aref (buffer-name buf) 0) ?\ )
-                       (and (not hycontrol--invert-display-buffer-predicates)
-                            (not (eval (cons 'or 
(hycontrol-display-buffer-predicate-results buf)))))
-                       (and hycontrol--invert-display-buffer-predicates
-                            (not (eq 
hycontrol--invert-display-buffer-predicates 'ignore))
-                            (eval (cons 'or 
(hycontrol-display-buffer-predicate-results buf))))))
-      ;; Buffer is not one to display, get the next one and test again.
-      (setq buf (car hycontrol--buffer-list-pointer)
-           hycontrol--buffer-list-pointer (cdr 
hycontrol--buffer-list-pointer)))
-    (set-window-buffer window
-                      (or buf
-                          ;; Out of buffers to display, display a blank one
-                          hycontrol--blank-buffer))))
+  (unless (or (null window) (window-dedicated-p window))
+    (let ((buf (car hycontrol--buffer-list-pointer)))
+      (setq hycontrol--buffer-list-pointer (cdr 
hycontrol--buffer-list-pointer))
+      (while (and buf (or (= (aref (buffer-name buf) 0) ?\ )
+                         (and (not hycontrol--invert-display-buffer-predicates)
+                              (not (eval (cons 'or 
(hycontrol-display-buffer-predicate-results buf)))))
+                         (and hycontrol--invert-display-buffer-predicates
+                              (not (eq 
hycontrol--invert-display-buffer-predicates 'ignore))
+                              (eval (cons 'or 
(hycontrol-display-buffer-predicate-results buf))))))
+       ;; Buffer is not one to display, get the next one and test again.
+       (setq buf (car hycontrol--buffer-list-pointer)
+             hycontrol--buffer-list-pointer (cdr 
hycontrol--buffer-list-pointer)))
+      (set-window-buffer window
+                        (or buf
+                            ;; Out of buffers to display, display a blank one
+                            hycontrol--blank-buffer)))))
 
 (defun hycontrol-window-display-buffer-with-repeats (window)
   "This is no longer used since Hyperbole V8.  Left here for reference.
diff --git a/hyperbole.el b/hyperbole.el
index eed5a3a9d3..72be5db307 100644
--- a/hyperbole.el
+++ b/hyperbole.el
@@ -9,7 +9,7 @@
 ;; Maintainer:   Robert Weiner <rsw@gnu.org>
 ;; Maintainers:  Robert Weiner <rsw@gnu.org>, Mats Lidell <matsl@gnu.org>
 ;; Created:      06-Oct-92 at 11:52:51
-;; Last-Mod:     23-Aug-24 at 22:36:12 by Bob Weiner
+;; Last-Mod:     11-Nov-24 at 00:03:01 by Bob Weiner
 ;; Released:     10-Mar-24
 ;; Version:      9.0.2pre
 ;; Keywords:     comm, convenience, files, frames, hypermedia, languages, 
mail, matching, mouse, multimedia, outlines, tools, wp
@@ -522,6 +522,11 @@ frame, those functions by default still return the prior 
frame."
     (hyperb:init)
     (remove-hook 'after-init-hook #'hyperb:init))
   ;;
+  ;; Update mode-line hover doc in blank areas for button-2 and
+  ;; button-3 if using unshifted Smart Keys.
+  (set-variable mode-line-default-help-echo 
#'hmouse-modeline-default-help-echo)
+  (force-mode-line-update t)
+  ;;
   ;; Abbreviate MSWindows /cygdrive mount point paths.
   (when (file-exists-p "/cygdrive")
     (add-to-list 'directory-abbrev-alist hyperb:cygdrive))
diff --git a/hywiki.el b/hywiki.el
index 57accd7add..2327170a30 100644
--- a/hywiki.el
+++ b/hywiki.el
@@ -3,7 +3,7 @@
 ;; Author:       Bob Weiner
 ;;
 ;; Orig-Date:    21-Apr-24 at 22:41:13
-;; Last-Mod:     28-Oct-24 at 01:43:34 by Bob Weiner
+;; Last-Mod:     10-Nov-24 at 15:44:27 by Bob Weiner
 ;;
 ;; SPDX-License-Identifier: GPL-3.0-or-later
 ;;
@@ -142,6 +142,7 @@
 (declare-function hsys-org-at-tags-p "hsys-org")
 (declare-function org-link-store-props "ol" (&rest plist))
 (declare-function org-publish-property "ox-publish" (property project 
&optional default))
+(declare-function smart-treemacs-edit "hui-treemacs" (&optional dir))
 
 ;;; ************************************************************************
 ;;; Public variables
@@ -834,10 +835,33 @@ these are handled by the Org mode link handler."
                 0)))))
 
 (defun hywiki-directory-edit ()
-  "Display and edit HyWiki pages in current `hywiki-directory'."
+  "Edit HyWiki pages in current `hywiki-directory'.
+Use `dired' unless `action-key-modeline-buffer-id-function' is set to
+`smart-treemacs-modeline', then use `treemacs'."
   (interactive)
-  (dired (concat hywiki-directory "[[:upper:]][[:alpha:]]*"
-                (regexp-quote hywiki-file-suffix))))
+  (if (eq action-key-modeline-buffer-id-function #'smart-treemacs-modeline)
+      (hywiki-directory-treemacs-edit)
+    (hywiki-directory-dired-edit)))
+
+(defun hywiki-directory-dired-edit ()
+  "Use `dired' to edit HyWiki pages in current `hywiki-directory'."
+  (interactive)
+  (let ((case-fold-search nil)
+       (shell-name (or shell-file-name "")))
+    (if (string-match-p "bash\\(\\.exe\\)?$" shell-name)
+       (dired (concat hywiki-directory
+                      "[[:upper:]][[:alpha:]]*"
+                      (regexp-quote hywiki-file-suffix)))
+      (dired (cons hywiki-directory
+                  (directory-files hywiki-directory nil
+                                   (format "^[A-Z][A-Za-z]*%s$"
+                                           (regexp-quote 
hywiki-file-suffix))))))))
+
+(defun hywiki-directory-treemacs-edit ()
+  "Use `treemacs' to edit HyWiki pages in current `hywiki-directory'."
+  (interactive)
+  (require 'hui-treemacs)
+  (smart-treemacs-edit hywiki-directory))
 
 (defun hywiki-directory-get-checksum ()
   "Compute and return the checksum for the current set of HyWiki pages."
@@ -1149,7 +1173,7 @@ If in a programming mode, must be within a comment.  Use
          (unless hywiki--highlighting-done-flag
            (unless on-page-name
              ;; May be a closing delimiter that we have to skip past
-             (skip-chars-backward (regexp-quote hywiki--buttonize-characters)))
+             (skip-chars-backward (regexp-quote 
(hywiki-get-buttonize-characters))))
            ;; Skip past HyWikiWord or section
            (skip-syntax-backward "^-$()<>._\"\'")
            (skip-chars-backward "-_*#[:alpha:]")
@@ -1220,7 +1244,7 @@ the current page unless they have sections attached."
            (unless hywiki--highlighting-done-flag
              (unless on-page-name
                ;; May be a closing delimiter that we have to skip past
-               (skip-chars-backward (regexp-quote 
hywiki--buttonize-characters)))
+               (skip-chars-backward (regexp-quote 
(hywiki-get-buttonize-characters))))
              ;; Skip past HyWikiWord or section
              (skip-syntax-backward "^-$()<>._\"\'")
              (skip-chars-backward "-_*#[:alpha:]")
diff --git a/man/hkey-help.txt b/man/hkey-help.txt
index 6ec097bff3..8ee3f7ba13 100644
--- a/man/hkey-help.txt
+++ b/man/hkey-help.txt
@@ -66,7 +66,7 @@ Mouse-only Control
     Buffer ID                   Dired on buffer's dir      Displays next buffer
                                   or on parent when a dir
     Other blank area            Action Key modeline hook   Assist Key modeline 
hook
-                                  Shows/Hides Buffer Menu    Popups Jump & 
Manage Menu
+                                  Shows/Hides Buffer Menu    Popups Screen & 
Jump Menus
 
   Drag in window, region active Error, not allowed         Error, not allowed
   Horizontal drag in a window   Splits window below        Deletes window
diff --git a/man/hyperbole.info b/man/hyperbole.info
index 4248c9a6da..0e816ea4ac 100644
Binary files a/man/hyperbole.info and b/man/hyperbole.info differ
diff --git a/man/hyperbole.texi b/man/hyperbole.texi
index d6447fd7a3..9ffdc046ca 100644
--- a/man/hyperbole.texi
+++ b/man/hyperbole.texi
@@ -7,7 +7,7 @@
 @c Author:       Bob Weiner
 @c
 @c Orig-Date:     6-Nov-91 at 11:18:03
-@c Last-Mod:     27-Oct-24 at 23:09:15 by Bob Weiner
+@c Last-Mod:     10-Nov-24 at 16:01:31 by Bob Weiner
 
 @c %**start of header (This is for running Texinfo on a region.)
 @setfilename hyperbole.info
@@ -57,6 +57,12 @@
 @itemx @bkbd{\key\}
 @end macro
 
+@c In PDF output, like Info output, display only the label of an @uref
+@c or @url link when given.
+@tex
+\global\urefurlonlylinktrue
+@end tex
+
 @copying
 This manual is for GNU Hyperbole
 (Edition @value{EDITION}, Published @value{UPDATED}).
@@ -602,14 +608,14 @@ archives, the World-Wide Web and much more.
 @cindex Hyperbole demo
 @cindex demo file
 @cindex tutorial
-This is a reference manual with extensive details about Hyperbole use.  If
-you prefer a simpler, more interactive introduction to Hyperbole, the
-@file{FAST-DEMO} file included in the Hyperbole distribution demonstrates
-many of Hyperbole's standard facilities without the need to read through this
-reference manual.  The @file{FAST-DEMO} is a good way to rapidly understand
-some of what Hyperbole can do for you.  Once Hyperbole is installed,
-(@pxref{Setup}), you can access the @file{FAST-DEMO} with the key sequence
-@bkbd{C-h h d d}.
+This is a reference manual with extensive details about Hyperbole use.
+If you prefer a simpler, more interactive introduction to Hyperbole,
+the @file{../FAST-DEMO} file included in the Hyperbole distribution
+demonstrates many of Hyperbole's standard facilities without the need
+to read through this reference manual.  The @file{../FAST-DEMO} is a good
+way to rapidly understand some of what Hyperbole can do for you.  Once
+Hyperbole is installed, (@pxref{Setup}), you can access the
+@file{../FAST-DEMO} with the key sequence @bkbd{C-h h d d}.
 
 @xref{Glossary}, for definitions of Hyperbole terms.  In some cases,
 terms are not precisely defined within the body of this manual since they
@@ -1027,7 +1033,7 @@ access to HyControl's window control menu if it was not 
already bound
 prior to Hyperbole's initialization.
 
 Videos demonstrating Hyperbole's features are listed at
-@url{https://gnu.org/s/hyperbole}.
+@uref{https://gnu.org/s/hyperbole}.
 
 The above are the best interactive ways to learn about Hyperbole.
 
@@ -1390,7 +1396,7 @@ Hyperbole has some radically cool ways to select regions 
of structured text
 or source code and to copy or move them between buffers with a single mouse
 drag or two key presses.  A great deal of smarts are built-in so that it
 does the right thing most of the time; many other attempts at similar
-behavior such as @file{thing.el} fail to deal with many file format
+behavior such as @file{thingatpt.el} fail to deal with many file format
 complexities.
 
 We use the term @dfn{things} to refer to structured entities that
@@ -1826,7 +1832,7 @@ are not supported without a window system.
 @cindex keyboard, jump to window
 For even faster keyboard-based display of items and drag emulations,
 use the Emacs package @code{ace-window}
-(see @url{https://elpa.gnu.org/packages/ace-window.html}).
+(see @uref{https://elpa.gnu.org/packages/ace-window.html}).
 
 The @dfn{ace-window} package assigns short letter IDs to each Emacs
 window and lets you jump to or operate upon a specific window by giving
@@ -2331,7 +2337,7 @@ Below is a list of standard implicit button types in the 
order in
 which Hyperbole tries to match to the types when looking for an
 implicit button (decreasing priority order).  @bkbd{C-h h i t
 @key{RET}} provides similar information.  See the Hyperbole file,
-@file{hibtypes.el}, for examples of how to define implicit button
+@file{../hibtypes.el}, for examples of how to define implicit button
 types (in the file, they are listed in reverse order, increasing in
 priority).
 
@@ -2798,11 +2804,11 @@ associated section.  Or try it in the Hyperbole 
@file{DEMO} file.
 @cindex C/C++ cross-reference
 @cindex Cscope
 @item cscope
-Jump to a C/C++ source line associated with a Cscope C analyzer output line.
-The cscope.el Lisp library available from the Emacs package manager
-must be loaded and the open source cscope program available from
-http://cscope.sf.net must be installed for this button type to do
-anything.
+Jump to a C/C++ source line associated with a Cscope C analyzer output
+line.  The cscope.el Lisp library available from the Emacs package
+manager must be loaded and the open source cscope program available
+from @uref{http://cscope.sf.net} must be installed for this button
+type to do anything.
 
 @findex ibtypes etags
 @cindex etags entry
@@ -4331,7 +4337,7 @@ Web/ -             Select a search engine and term and 
search with them or
                    which determines whether web search results are displayed
                    within Emacs or with an external web browser.  A short
                    video introduction to the Find/Web menu may be
-                   found at @url{https://youtu.be/8lMlJed0-OM}.
+                   found at @uref{https://youtu.be/8lMlJed0-OM}.
 
                    The Find/Web menu looks like this:
 
@@ -4620,33 +4626,54 @@ many files with interactive search pattern narrowing.
 @noindent
 Below are descriptions of each menu item.
 
-@findex hywiki-consult-grep
 @cindex HyWiki menu
 @cindex menu, HyWiki
 @table @asis
+@cindex HyWiki activate link 
 @item Act
 Activate HyWikiWord link at point.
 
+@cindex HyWiki create a page
 @item Create
-Create and display a new HyWiki page.  Shows existing page names to aid in new 
naming.
+Create and display a new HyWiki page.  Shows existing page names to
+aid in new naming.
 
+@vindex hywiki-directory
+@vindex action-key-modeline-buffer-id-function
+@findex dired
+@findex smart-treemacs-modeline
+@findex treemacs
+@cindex HyWiki dired
+@cindex HyWiki treemacs
+@cindex HyWiki edit pages
 @item EditPages
-Display and edit HyWiki pages in current @code{hywiki-directory}.
+Display and edit HyWiki pages in current @code{hywiki-directory}.  Use
+@code{dired} unless @code{action-key-modeline-buffer-id-function} is
+set to @code{smart-treemacs-modeline}, then use the @code{treemacs}
+package.
 
+
+@cindex HyWiki find/edit a page
 @item FindPage
 Prompt with completion for and find a HyWiki page, typically editable.
 If the page is already in a buffer, point is left unchanged.
 
+@cindex HyWiki interactive grep
+@findex hywiki-consult-grep
 @item GrepConsult
 Grep over HyWiki pages with interactive @code{hywiki-consult-grep}.
 Any words may be used.
 
+@cindex HyWikiWord attribute help
 @item Help
 Report on a HyWikiWord's attributes.
 
+@cindex HyWiki documentation
+@cindex HyWiki manual
 @item Info
 Display Hyperbole manual section on HyWiki.
 
+@cindex HyWikiWord link
 @item Link
 Prompt for and add a link at point to a HyWiki page.
 
@@ -4676,14 +4703,17 @@ undefined HyWikiWords; otherwise, you must use 
@bkbd{C-h h h c} to create a
 new HyWiki page instead.  Use @samp{None} if you want to
 use Org's @bkbd{M-@key{RET}} command in every context within Org mode.
 
+@cindex HyWiki publish to web
 @item Publish
 Publish modified pages in the HyWiki to HTML; prefix arg to publish all pages.
 
-@cindex HyWiki tag search
+@cindex HyWiki search for Org tags
 @cindex search, HyWiki tag
 @item TagFind
 Find a matching Org tag across all HyWiki pages.
 
+@cindex HyWikiWord interactive grep
+@findex hywiki-consult-grep
 @item WikiWordConsult
 Use @code{hywiki-consult-grep} to prompt for a HyWikiWord and then
 consult grep for and select an occurrence within the HyWiki.
@@ -5924,7 +5954,7 @@ have alphanumeric statement identifiers on the right 
side.  You can
 import such files while maintaining their outline structure.  Use
 @bkbd{M-x kimport:aug-post-outline @key{RET}} and you will be
 prompted for the Augment buffer or file to import and the koutline to
-create.  See @url{https://dougengelbart.org/content/view/148/} for more
+create.  See @uref{https://dougengelbart.org/content/view/148/} for more
 information.
 
 @node Exporting,  , Inserting and Importing, Editing Outlines
@@ -6966,7 +6996,7 @@ If you use Google/Gmail Contacts, you can configure the 
HyRolo to
 query your Google Contacts for matches.  First you must download and
 install the external @file{google-contacts} package using the Emacs
 Package Manager.  Then you must install the non-Emacs GNU Privacy
-Guard (GPG) package from @url{https://gnupg.org} so that
+Guard (GPG) package from @uref{https://gnupg.org} so that
 the @file{gpg} or @file{gpg2} executable is in your command-line
 search path.  Once these are in place, either restart Emacs or
 use @bkbd{M-x hyrolo-initialize-file-list @key{RET}} to add Google
@@ -8289,7 +8319,7 @@ the current buffer.  This number makes the label unique 
and so allows
 any number of buttons with the same base label within a single buffer.
 
 @item Jedi
-See also @url{https://tkf.github.io/emacs-jedi/latest/}.
+See also @uref{https://tkf.github.io/emacs-jedi/latest/}.
 
 Jedi is a Emacs package for Python completion, definition and documentation 
lookup.
 
@@ -8375,7 +8405,7 @@ See @b{Augment}.
 See @b{Link} or @b{Cell}.
 
 @item The OO-Browser
-See also @url{https://www.gnu.org/software/oo-browser}.
+See also @uref{https://www.gnu.org/software/oo-browser}.
 
 The GNU OO-Browser is a multi-windowed, interactive object-oriented class
 browser similar in use to the well-known Smalltalk browsers.  It runs
@@ -8721,12 +8751,12 @@ Download either:
 
 @table @asis
 @item 1. a stable release tar.gz source archive from either:
-@url{ftp://ftp.gnu.org/gnu/hyperbole/} or
-@url{http://ftpmirror.gnu.org/hyperbole/}, which will find the closest
+@uref{ftp://ftp.gnu.org/gnu/hyperbole/} or
+@uref{http://ftpmirror.gnu.org/hyperbole/}, which will find the closest
 mirror of the GNU ftp site and show it to you.
 
 @item 2. the latest in-development pre-release tar.gz source archive linked to 
at the top of this web page:
-@url{https://elpa.gnu.org/devel/hyperbole.html}.
+@uref{https://elpa.gnu.org/devel/hyperbole.html}.
 @end table
 
 Then decompress and unpack the archive to a directory of your
@@ -10558,18 +10588,16 @@ Treemacs items may be dragged with the Action Key to 
other windows for display.
 @group
 When in a Treemacs file browser buffer:
   ACTION KEY or ASSIST KEY
-     (1) on an entry icon, the treemacs TAB command is run to expand and
-         collapse the entry;
-     (2) elsewhere within an entry line, the item is displayed for editing,
-         normally in another window;
-     (3) at the end of an entry line: if an Action Key press, invokes
+     (1) on or to the left of an entry icon, run the treemacs TAB command
+         to expand or collapse the entry;
+     (2) elsewhere within an entry line, display the item, which may be a
+         directory, for editing, normally in another window;
+     (3) at the end of an entry line: if an Action Key press, invoke
          @code{action-key-eol-function}, typically to scroll up proportionally;
-         if an Assist Key press, invokes @code{assist-key-eol-function}, 
typically
+         if an Assist Key press, invoke @code{assist-key-eol-function}, 
typically
          to scroll down proportionally;
-     (4) on the first line of the buffer (other than the end of line),
-         dired is run on the current directory of this Treemacs;
-     (5) at the end of the first or last line of the buffer,
-         this Treemacs invocation is quit.
+     (4) at the end of the first or last line of the buffer, quit this
+         Treemacs invocation.
 @end group
 @end format
 
@@ -12098,7 +12126,7 @@ more deeply.  In fact, it makes sense to use them 
together and they
 are highly compatible.  The only overlap we see is that Org-mode has a
 more limited kind of hyperlinks and offers some BBDB integration as
 Hyperbole does.  For a list of some differences, see:
-@url{https://www.emacswiki.org/emacs/Hyperbole}.
+@uref{https://www.emacswiki.org/emacs/Hyperbole}.
 
 Org-mode offers traditional Emacs outlining, todo list management,
 agenda and diary management, so it is very complementary to Hyperbole.



reply via email to

[Prev in Thread] Current Thread [Next in Thread]