Skip to content

Hyperbole 8.0.0: May 2022 Release

Compare
Choose a tag to compare
@rswgnu rswgnu released this 01 May 15:12
· 1069 commits to master since this release
** HYPERBOLE SYSTEM

  *** Installation: Hyperbole package installation options are greatly expanded.
      Stable or in-development branches may be installed with the Emacs package
      manager.  The Straight package manager may be used to keep up with
      git-based development and submit pull requests.  And stable and
      in-development tar balls are available for manual installation.  See
      "(hyperbole)Installation".

  *** Global Minor Mode: Hyperbole is now a global minor mode that can be
      toggled with {M-x hyperbole-mode RET}, meaning all of its key bindings
      can easily be enabled or disabled whenever desired.  Your init file needs
      to have (hyperbole-mode 1) in it instead of (require 'hyperbole) or
      Hyperbole will not be enabled upon startup.  See "(hyperbole)Usage".

      Modeline Indicator: In the modeline where minor modes are shown,
      "Hypb" now appears whenever Hyperbole is active.

      Hooks: When hyperbole-mode is enabled, hyperbole-mode-hook and
      hyperbole-mode-on-hook are run.  When hyperbole-mode is disabled,
      hyperbole-mode-hook and hyperbole-mode-off-hook are run.

      Lexical Binding: All code is now largely lexically bound, improving
      quality and debugability.


** ORG MODE

  *** M-RET: Reworked M-RET interface so can control how much or little of
      Hyperbole works in Org mode when Hyperbole minor mode is enabled.
      See "(hyperbole)enable org-mode support" and "hsys-org.el".

  *** hsys-org-enable-smart-keys: New customization to replace
      'inhibit-hsys-org'.  This applies only in Org major/minor modes when
      hyperbole-mode is active.  t means enable Smart Key support
      everywhere.  The symbol, buttons, is the default; it means the Smart
      Keys are active only when point is within a Hyperbole button.  A nil
      value means no Smart Key support so {M-RET} behaves just as it does
      normally in Org mode.  See "(hyperbole)Org-mode".  Use {C-h h c o}
      to customize this setting.

      This table summarizes the operation:

      |--------------+-------------------+------------------+----------+------------------|
      | Set To       | Smart Key Context | Hyperbole Button | Org Link | Fallback Command |
      |--------------+-------------------+------------------+----------+------------------|
      | buttons      | Ignore            | Activate         | Activate | org-meta-return  |
      | nil          | Ignore            | Ignore           | Ignore   | org-meta-return  |
      | t            | Activate          | Activate         | Activate | None             |
      |--------------+-------------------+------------------+----------+------------------|


** EASILY CREATE YOUR OWN BUTTON TYPES

  *** Simple Action Link Button Type Creation: `defal' is a new,
      easy-to-use construct that generates new action button types from
      a type name and a single simple format expression, allowing
      non-programmers to create their own implicit action button link
      types that execute key series, display URLs, display the contents
      of pathnames or invoke functions.  See "(hyperbole)Action Button
      Link Types" or the "DEMO2#Defining New Action Button Types"
      section.

  *** Easy Implicit Link Button Type Creation: 'defil' is a new
      construct for those familiar with regular expressions but not
      much Emacs Lisp.  This creates more flexible implicit button
      types than 'defal' where the delimiters and text substitution
      can be specified with regular expressions.  Actions are limited
      to executing key series, displaying URLs, displaying the
      contents of pathnames or invoking functions.  See
      "(hyperbole)Implicit Button Link Types".

      Elisp programmers should use the existing 'defib' macro for full
      flexibility in implicit button type creation.  See "hibtypes.el"
      for examples and "(hyperbole)Programmatic Implicit Button Types"
      for documentation.


** TEST CASES

  *** Hyperbole Automated Testing: Extensive quality improvements throughout
      Hyperbole thanks in part to over 230 test cases now included in the
      test/ subdirectory.  Simply run 'make test-all' or 'make test' from the
      command-line when in the Hyperbole source directory and you should see
      all tests pass.  If any fail, you can press the Action Key to see the
      source of the failure.  Full testing is supported under POSIX systems
      only.  See "Makefile" and "test/MANIFEST".
 
  *** Implicit Button Types to Run Tests: The file "hypb-ert.el" contains two
      action link types:
        hyperbole-run-test  - run a single Hyperbole test by name
        hyperbole-run-tests - run one more tests matching a pattern
      
        Example uses:
          Run the test hbut-defal-url
            <hyperbole-run-test hbut-defal-url>

          Run the tests specified by the test selector hbut-defal
            <hyperbole-run-tests hbut-defal>

          Run all tests
            <hyperbole-run-tests t>
 
  *** Installation Testing: install-test/local-install-test.sh automatically
      installs Hyperbole for testing from one or more of its releases or
      development branches.  See "Makefile" and "install-test/MANIFEST".


** HYROLO  (See "(hyperbole)HyRolo").

  *** Faster searching within HyRolo match buffer: After performing a HyRolo
      search with point in the match buffer, if you want different results,
      you can quickly do a new regular expression HyRolo search with {r} or
      a string/logical search with {C-u r}.  This key had moved to previous
      matches but that is already bound to {Shift-TAB} and {M-TAB}.

  *** Auto-Expansion of Entries: If an entry is collapsed/hidden, moving to
      any hidden part auto-expands it and then re-collapses it when point is
      moved to another entry (just like isearch).  A side-effect of this is
      that the {h} hide entry subtree command now moves to the beginning of
      the entry.

  *** hyrolo-find-file: New command that selects and edits a file in
      'hyrolo-file-list', defaulting to the first listed file when not given
      a prefix arg.  Available in the minibuffer menu as Rolo/File and the
      pulldown menu as Rolo/Find-HyRolo-File.

  *** Sorting Entries Rewritten:  {C-h h r o} re-ordering HyRolo entries has
      been rewritten for compatibility and improved debugging with the latest
      Emacs releases.

  *** hyrolo-highlight-face: Now uses the Emacs 'match' face by default.

  *** Under MS Windows, the default HyRolo file is now "~/.rolo.otl" like
      all other operating systems, instead of "~/_rolo.otl".  Any older file
      name will be relocated to the newer name.


** KOUTLINER  (See "(hyperbole)Koutliner").

  *** Export Koutlines to Collapsible Web Pages: {C-h h k f d} or
      {M-x kexport:display RET} command creates and displays a web-based
      expandable/collapsible outline from the Koutline in the current buffer.
      See "(hyperbole)Exporting" and the new Koutliner Format submenu.

  *** Org File Importation: Org files may now be imported to a Koutline using
      {M-x kimport:file RET}.

  *** Org Table Support: Org table editing now automatically works in the
      Koutliner via Org table minor mode.  Use {M-x orgtbl-mode RET} to
      toggle this on and off.  A press of the Action Key on a | symbol,
      also toggles this minor mode on or off. See "(Org)Tables" for details.
      Use a prefix arg with {TAB} to promote/demote Koutline trees when in
      a table since {TAB} moves between fields within a table.

  *** New Tree Movement Commands: Like Org mode, {[M-down]} and {[M-up]} move
      the current tree past or before other trees at the same level.  With a
      prefix argument, move past that many trees.

  *** New Tree Promotion/Demotion Keys: Tree promotion and demotion keys now
      match many of the defaults in Org mode and Outline mode, plus some
      easier to type ones.  The tables below summarize which keys work whether
      inside an Org table or outside.  See "(hyperbole)Promoting and Demoting".

      |----------------------------+-----------------------------|
      | Promotion Inside Org Table | Demotion Inside Org Table   |
      |----------------------------+-----------------------------|
      | M-0 Shift-TAB or M-0 M-TAB | M-0 TAB                     |
      | C-c C-,                    | C-c C-.                     |
      | C-c C-<                    | C-c C->                     |
      |----------------------------+-----------------------------|

      |-----------------------------+----------------------------|
      | Promotion Outside Org Table | Demotion Outside Org Table |
      |-----------------------------+----------------------------|
      | Shift-TAB or M-TAB          | TAB                        |
      | M-left                      | M-right                    |
      | C-c C-,                     | C-c C-.                    |
      | C-c C-<                     | C-c C->                    |
      |-----------------------------+----------------------------|

  *** New Mail Tree Key Binding: The 'kotl-mode:mail-tree' command that
      extracts the current view of a Koutline in text-only format and
      creates an outgoing email message with it, has moved from {C-c @}
      to {C-c C-@} to prevent conflict with the global hycontrol-window-grid
      command bound to {C-c @}.

  *** New Copy Command: The new command, 'kotl-mode:copy-tree-or-region-to-buffer',
      bound to {C-c M-c} copies a Koutline tree or the active region
      to a specified buffer.  Prompts dictate whether invisible text
      is included or not.  This allows copying parts of Koutlines
      directly into other buffers without having to copy to a
      mail/message buffer first.

  *** Klink Copy: When 'transient-mark-mode' is enabled and there is no active region:

        within a link to a Koutline cell (klink), {M-w} copies the klink; then
        {C-y} yanks it into any buffer you desire.

        {M-w} outside of a klink instead copies a reference to the current
        Koutline cell.

        {C-x r s} prompts for an Emacs register and saves either the current
        klink or the current cell reference to the register; {C-x r i} with the
        same register then inserts at point the saved Koutline reference.

      The new commands that you can bind to your own keys for copying klink
      references to the current cell to the kill ring and to registers are:
        kotl-mode:copy-absolute-klink-to-kill-ring
        kotl-mode:copy-relative-klink-to-kill-ring
        kotl-mode:copy-absolute-klink-to-register
        kotl-mode:copy-relative-klink-to-register

  *** Klinks Ignored Outside Comments in Programming Language Modes: In
      previous Hyperbole versions, this was true for C-based language
      modes.  Now it is true for any programming mode descended from
      'prog-mode'.

  *** Prevent Movement Outside Editable Cell Bounds: Add
      kotl-mode:pre-self-insert-command as a pre-command-hook
      to prevent Koutline editing with point in an invalid location,
      after a mouse-set-point outside of editable bounds.

  *** {C-h h k e} (kotl-mode:example): Update to allow for an optional
      directory or absolute file path.  Prompt for the path when interactive.
      Given a prefix argument, archive any existing file and start with a
      fresh EXAMPLE.kotl file for editing.  Programmatically, give a 2nd
      arg of t to force archiving of any existing file and starting with
      a fresh EXAMPLE.kotl file.

  *** Koutlines have a hidden top-level root cell 0 that allows referring
      to the whole outline as a tree.  Now attributes of this cell can be
      set, retrieved or removed like any other cell.

      {C-c h} prompts for a kcell id and displays its attributes.
      {C-u C-c h} prompts for a kcell id and displays the attributes for it
      and its subtree; use 0 as the kcell id to see attributes for all visible
      cells in the outline.

      {C-c C-i} sets an attribute of the cell at point.
      {C-u C-c C-i} removes an attribute of the cell at point.
      {C-0 C-c C-i} sets an attribute of the invisible 0 root cell.
      {C--1 C-c C-i} removes an attribute of the invisible 0 root cell.

  *** Modes to Ignore Klinks: C-style languages use <includes> that can be
      mistaken for klinks.  New customizations 'klink:ignore-modes' and
      'klink:c-style-modes' set the modes where klink matches are ignored.


** MENUS

  *** Minibuffer Menu Changes:
        - Items Activated by First Capital Letter: Used to be by the first
          letter.  This allows more flexibility in naming, e.g.
          where two items start with the same first letter.

        - {X} exits Hyperbole mode: This disables the Hyperbole minor mode
          completely and exits from the menu.  {C-h h} re-enables the
          global minor mode and display the top-level Hyperbole menu.

  *** Minibuffer and Pulldown Menu Changes:

        - Find/Web/Jump: Use the Emacs webjump library to select a URL by name
          and jump to it.

        - Koutliner Formatting Menus: Full set of commands to import
          text and outline files to Koutlines and to export Koutlines
	  to HTML for web viewing.  See "(hyperbole)Inserting and Importing"
          and "(hyperbole)Exporting".

        - Button Modify Commands Removed: Use the Edit commands instead.
          This applies to the pull-down menu as well.


** SMART (ACTION AND ASSIST) KEYS  (See "(hyperbole)Smart Keys").

  *** Explicit buttons may be created in any kind of temporary buffer
      without an attached file, similar to what already existed for mail
      message buffers.

  *** 'ls' and 'grep' Directory Changes:  'ls' listings are now recognized
      properly, prepending the preceding directory to each entry for viewing.

      Similarly, if a 'cd' or 'pushd' command is issued prior to a 'grep -n'
      or 'ripgrep' command, Hyperbole will prepend that directory to the grep
      output before jumping to the resultant path.

  *** Git Log Grep: New commands, 'hypb:fgrep-git-log' and 'hypb:grep-git-log',
      allow f/grepping over repo changesets and listing associated commit log
      messages.  The Action Key on any resulting log entry displays the commit
      changeset.

  *** Pathname Implicit Buttons: Much improved pathname handling including
      multiple variables per path, embedded . or .. within paths, better
      recognition of semicolon separated pathnames in Windows PATH variable.

      Variable substitutions are now made with fixed case, so that the
      case of a value with both upper and lower case characters is
      never changed, for example a value of ${HOME}.

      Generalized Anchored Pathnames:  "pathname#anchor" now works in
      programming modes as well as text and outlining modes where anchors
      are prefixed with the comment character in each mode or a # symbol.

      PATH-style Variable Support:  An Action Key press on a defined PATH-style
      variable name, e.g. MANPATH, will prompt with completion for one of the
      paths and will then display that.  If it is the colon or semicolon-
      separated string of paths value from a PATH-style variable, the path at
      point is displayed; empty paths, e.g. :: represents the current directory,
      ’.’.  Must have at least four paths within the variable value for this
      to work.

      file:// URLs are now resolved properly.

  *** Any Lisp or environment variable that stores a directory or set of
      directories may be prepended to any "grep -n" output line with the form
      "${var-name}/" and the Action Key will recognize the directory and display
      the appropriate line.

  *** Treat kbd Strings as Key Series Buttons: An Action Key press within
      the string of (kbd "string") issues the keys in string as if they were
      pressed individually, i.e. the same as the key series, {string}.

  *** Mail Address Activation Everywhere: Email addresses are recognized as
      implicit buttons in major modes descended from 'mail-address-mode-list'.
      If you set that to nil, however, they will be recognized in all major
      modes.

  *** Magit Mode Support: Just click or press the Action Key somewhere and it
      will typically display what you want.  Extensive Action Key support in
      Magit modes for cycling through display views and displaying items.

      Action Mouse clicks on the modeline cycles display of commits/diffs in
      a buffer.  In Magit Log and Blame listing modes, the Action Key
      displays the associated commit or file line.  The Action Key also
      handles single line log entries that begin with the word 'commit' ,
      displaying their commits even from shell and compilation buffers.

  *** Debugger Source: In Python tracebacks, may be on a line just below the
      source reference line so if not on a Hyperbole button, move back a line
      before checking.

  *** Todotxt Mode Support: Smart key support for the todotxt mode
      https://github.com/rpdillon/todotxt.el.

  *** UNIX Shell Errors: Jump to associated source line from a shell error of the
      form:  "<pathname>: line <num>: ".

  *** Internet RFC Links (e.g. RFC-822): Change to using http to retrieve RFCs
      instead of ftp since this is disabled in many environments.  Always display
      with Emacs' web browser rather than externally.

  *** Implicit Button Types Reprioritization: Modified "hibtypes.el" so if
      evaluate: (symset:clear 'ibtypes) and then reload hibtypes.{el,elc},
      the priority order of all implicit button types is reset.


** CUSTOMIZATION

  *** Customizable Display Program File Mappings:
      The variables:
         hpath:internal-display-alist
         hpath:external-display-alist-macos
         hpath:external-display-alist-mswindows
         hpath:external-display-alist-x)
      are all customizable and their default values utilize the per operating
      system generic 'open' commands based on file suffix associations (for file
      types not handled by Emacs).

      The new customizable variable, 'hpath:external-file-suffixes', holds a regular
      expression of operating system independent file suffixes to open outside Emacs
      with the Action Key when not handled by 'hpath:native-image-suffixes'.


** PROGRAMMING

  *** With the Hyperbole menu Cust/Debug-Toggle enabled, the messages printed
      for each Smart Key press now include the action type and its arguments
      for improved debugging.

  *** Edebuggable Hyperbole Types: 'defib' and 'defact' type definitions
      are now interactively debuggable via edebug-defun {C-M-x}.

  *** ebut:program: Programmatically create an explicit Hyperbole button at
      point from LABEL, ACTYPE (action type), and optional actype ARGS.

  *** gbut:ebut-program: Programmatically add global explicit buttons at the
      end of the personal button file.
      
  *** kbd-key implicit button type: Interactive creation now allows for
      a full key series, not just a single key binding.

  *** kbd-key:is-p: Added this new predicate to test whether point is within
      a brace-delimited key series.

  *** kbd-key:execute: Added to programmatically or interactively execute a
      non-normalized key series stored in a string.

  *** hypb:def-to-buffer: Quick copying of program definitions and insertion
      at the start of another buffer.  Can be bound and used in key series.

  *** smart-lisp-find-tag: New function that automatically finds tags tables
      and jumps to Emacs Lisp definitions.  It can be used in any type
      of file as an action button, e.g. <smart-lisp-find-tag "ibut:at-p">.

  *** ibut:at-p: Trigger an error if any implicit button type predicate
      permanently moves point to simplify debugging such predicates.

  *** hypb:string-count-matches: Count regexp matches in a string.


** ACE WINDOW PACKAGE INTEGRATION - fast window and buffer switching

  *** After installing the ace-window package and loading Hyperbole, execute
      (hkey-ace-window-setup "\M-o") to enable the following capabilities:

  *** Fast Window Links: The hkey-window-link command bound to {M-o w}
      rapidly creates a link button at point in the selected window,
      linking to point in the window chosen when prompted.
      See "DEMO2#Displaying File and Buffer Items and Moving Buffers".

  *** Throw A Region Elsewhere Within the Same Buffer: {M-o t <window-id>}
      when used with a selected region can now throw to the source buffer
      as long as point is outside the selected region in the target window.