# isearch-mb
**Repository Path**: mirrors_minad/isearch-mb
## Basic Information
- **Project Name**: isearch-mb
- **Description**: No description available
- **Primary Language**: Unknown
- **License**: Not specified
- **Default Branch**: main
- **Homepage**: None
- **GVP Project**: No
## Statistics
- **Stars**: 0
- **Forks**: 0
- **Created**: 2021-05-15
- **Last Updated**: 2025-10-20
## Categories & Tags
**Categories**: Uncategorized
**Tags**: None
## README
Isearch-Mb
==========
This Emacs package provides an alternative Isearch UI based on the
minibuffer.  This allows editing the search string in arbitrary ways
without any special maneuver; unlike standard Isearch, cursor motion
commands do not end the search.  Moreover, in comparison with standard
Isearch, this package provides simplified visual feedback in the echo
area.
To use the package, just add the following to your init file:
``` elisp
(isearch-mb-mode)
```
Keybindings
-----------
During a search, `isearch-mb-minibuffer-map` is active.  By default,
it includes the following commands:
- C-s: `isearch-repeat-forward`
- C-r: `isearch-repeat-backward`
- M-<: `isearch-beginning-of-buffer`
- M->: `isearch-end-of-buffer`
- M-%: `isearch-query-replace`
- C-M-%: `isearch-query-replace-regexp`
- M-s prefix: similar to standard Isearch
Everything else works as in a plain minibuffer, e.g. RET
ends the search normally and C-g cancels it.
Some customization ideas
------------------------
Isearch provides a myriad of customization options, and most of them
make just as much sense in Isearch-Mb mode.  The following are some
uncontroversial settings that would make sense for most people:
``` elisp
(setq-default
 ;; Match count next to minibuffer prompt
 isearch-lazy-count t
 ;; Don't be stingy with history; default is to keep just 16 entries
 search-ring-max 200
 regexp-search-ring-max 200)
```
Note that since Isearch-Mb relies on a regular minibuffer, you can use
you favorite tool to browse the history of previous search strings
(say, the `consult-history` command from the excellent [Consult]
package).
Using regexp search by default is a popular option as well:
```elisp
(global-set-key (kbd "C-s") 'isearch-forward-regexp)
(global-set-key (kbd "C-r") 'isearch-backward-regexp)
```
For a Swiper-style fuzzy search, where spaces match any sequence of
characters in a line, use the settings below.  You can still toggle
strict whitespace matching with M-s SPC during a search.
``` elisp
(setq-default
 isearch-regexp-lax-whitespace t
 search-whitespace-regexp ".*?")
```
Interaction with other Isearch extensions
-----------------------------------------
Some third-party Isearch extensions need to be patched to work with
Isearch-Mb.  There are three cases to consider:
- **Commands that start a search** shouldn't require extra
  configuration.
  
- **Commands that operate during a search session** require the
  `isearch-mb--with-buffer` advice.  Examples of this case are
  [`loccur-isearch`][loccur] and [`consult-isearch`][consult]:
  
  ``` elisp
  (advice-add 'loccur-isearch :around 'isearch-mb--with-buffer)
  (define-key isearch-mb-minibuffer-map (kbd "C-o") 'loccur-isearch)
  
  (advice-add 'consult-isearch :around 'isearch-mb--with-buffer)
  (define-key isearch-mb-minibuffer-map (kbd "M-r") 'consult-isearch)
  ```
  
- **Commands that end the Isearch session** require the
  `isearch-mb--after-exit` advice.  Examples of this case are
  [`anzu-isearch-query-replace`][anzu] and
  [`consult-line`][consult]:
  ``` elisp
  (advice-add 'anzu-isearch-query-replace :around 'isearch-mb--after-exit)
  (define-key isearch-mb-minibuffer-map (kbd "M-%") 'anzu-isearch-query-replace)
  (advice-add 'consult-line :around 'isearch-mb--after-exit)
  (define-key isearch-mb-minibuffer-map (kbd "M-s l") 'consult-line)
  ```
[consult]: https://github.com/minad/consult
[loccur]: https://github.com/fourier/loccur#isearch-integration
[anzu]: https://github.com/emacsorphanage/anzu