Skip to content

szermatt/visual-replace

Repository files navigation

visual-replace

test Documentation Status MELPA stable MELPA

Visual Replace provides a nicer interface to Query-Replace on Emacs than the built-in one.

The main improvements are:

  • The prompt of Visual Replace includes both the text to be replaced and the replacement. This makes it easier to craft possibly complex regular expression search and replace.

  • You can see the matches and how they're going to be modified as you edit the command arguments.

  • To help craft the search string and its replacement, you can navigate between matches with the arrow keys and optionally see the number of matches in the prompt.

  • You can apply only some replacements, selectively, using keyboard shortcuts, or by clicking on the preview.

  • You can modify the scope and type of the search-and-replace command, to the full buffer, the region or everything after the point.

Visual Replace is only an interface for the existing query and replace mechanisms built into Emacs, that is, the actual replacements are always done by the standard Emacs commands.

example

The following is just a quick introduction. Read the full documentation at https://visual-replace.readthedocs.io/en/latest/ or, if you have already installed Visual Replace, in the Emacs info reader

The prompt also displays the mode of replacement:

  • textreplacement executes string-replace
  • text →? replacement executes query-replace
  • text →.* replacement executes replace-regexp
  • text →?.* replacement executes query-replace-regexp

More flags can be toggled, to control:

  • the scope of the replacement, region or whole buffer
  • whether search and replace applies on whole words only
  • with or without case-fold-search
  • with or without replace-lex-whitespace

If you leave visual-replace without confirming, with C-g, you can continue where you left off next time by going up in the history, with C-p.

After typing a few characters of the string to match visual-replace enters preview mode, and highlights the matches. It also scrolls the window to keep at least one example of matches visible. You can also press up and down to go through the matches. (C-p and C-n remain available to navigate through history.)

COMPARISON

What seems to be unique about visual-replace is the ability to edit both the thing to be replaced and the replacement at the same time. The other packages I've found make it a 2-step process.

visual-regexp also supports a preview, but uses its own search-and-replace mechanism and only supports a regexp mode.

anzu is otherwise very similar to visual-replace. It was abandoned for a long time, but has been recently taken up by a new maintainer.

INSTALLATION

You can install Visual Replace:

  • from MELPA, by typing M-x package-install visual-replace
  • from source, by executing (package-vc-install "https://github.com/szermatt/visual-replace")

To replace query-replace' with visual-replace' globally, do:

(require 'visual-replace)
(visual-replace-global-mode 1)

With use-package and with a custom key binding:

(use-package visual-replace
   :defer t
   :bind (("C-c r" . visual-replace)
          :map isearch-mode-map
          ("C-c r" . visual-replace-from-isearch)))

USAGE

Launch `visual-replace' with the keybinding you chose when installing, "M-%" by default.

In that mode:

  • "TAB" navigates between the text to replace and the replacement string
  • "RET" switches to the replacement string, the first time, then executes the replacement
  • "M-% SPC" modifies the scope of the search (full buffer, from point, region)
  • "M-% r" toggles regexp mode on and off
  • "M-% q" toggles query mode one and off
  • "M-% w" toggle limiting search to whole words
  • "M-% c" toggle case-fold
  • "M-% s" toggle lax whitespace

If you started visual-replace with another keybinding, replace M-% with that keybinding. Modify visual-replace-mode-map and visual-replace-secondary-mode-map to customize the keybindings.

visual-replace-from-isearch switches from an active isearch session to visual-replace.

visual-replace-thing-at-point starts a visual replace session with the symbol at point, or a specified thing as understood by thing-at-point.

visual-replace-selected starts with the text within the current active region.

TESTING

Install eldev, and run tests with:

eldev test

SOMETHING IS WRONG !

Please check the doc and, if that doesn't help, take the time to file a bug report.

CONTRIBUTING

See the Contributing section of the documentation.

COMPATIBILITY

Visual-Replace requires Emacs 26.1 or later.