Skip to content
/ swiper Public

Ivy - a generic completion frontend for Emacs, Swiper - isearch with an overview, and more. Oh, man!

Notifications You must be signed in to change notification settings

abo-abo/swiper

Repository files navigation

CI build badge

Flexible, simple tools for minibuffer completion in Emacs

This repository contains:

  • Ivy, a generic completion mechanism for Emacs.

  • Counsel, a collection of Ivy-enhanced versions of common Emacs commands.

  • Swiper, an Ivy-enhanced alternative to Isearch.

Ivy

Ivy badge from GNU-devel ELPA Ivy badge from GNU ELPA Ivy badge from MELPA Ivy badge from MELPA Stable

Ivy is a generic completion mechanism for Emacs. While it operates similarly to other completion schemes such as icomplete-mode, Ivy aims to be more efficient, smaller, simpler, and smoother to use yet highly customizable.

To try Ivy, just call M-x ivy-mode. This will enable generic Ivy completion, including specific completion for file and buffer names.

Installation

Install the ivy package from GNU ELPA or MELPA.

Users of Debian ≥10 (and derivatives such as Ubuntu ≥18.04) can install Ivy, Counsel, and Swiper with sudo apt install elpa-counsel. To add Hydra support: sudo apt install elpa-ivy-hydra.

Documentation

Manual

Installing ivy from GNU ELPA or MELPA also installs the manual under the (ivy) Info node.

The source file for the Info manual is ivy.org.

The manual is also available as HTML.

Wiki

There is an Ivy and Swiper wiki on GitHub.

Small config example

(ivy-mode)
(setopt ivy-use-virtual-buffers t)
(setopt enable-recursive-minibuffers t)
;; Enable this if you want `swiper' to use it:
;; (setopt search-default-mode #'char-fold-to-regexp)
(keymap-global-set "C-s" #'swiper-isearch)
(keymap-global-set "C-c C-r" #'ivy-resume)
(keymap-global-set "<f6>" #'ivy-resume)
(keymap-global-set "M-x" #'counsel-M-x)
(keymap-global-set "C-x C-f" #'counsel-find-file)
(keymap-global-set "<f1> f" #'counsel-describe-function)
(keymap-global-set "<f1> v" #'counsel-describe-variable)
(keymap-global-set "<f1> o" #'counsel-describe-symbol)
(keymap-global-set "<f1> l" #'counsel-find-library)
(keymap-global-set "<f2> i" #'counsel-info-lookup-symbol)
(keymap-global-set "<f2> u" #'counsel-unicode-char)
(keymap-global-set "C-c g" #'counsel-git)
(keymap-global-set "C-c j" #'counsel-git-grep)
(keymap-global-set "C-c k" #'counsel-ag)
(keymap-global-set "C-x l" #'counsel-locate)
(keymap-global-set "C-S-o" #'counsel-rhythmbox)
(keymap-set minibuffer-local-map "C-r" #'counsel-minibuffer-history)

Note: parts of this config can be replaced by using counsel-mode.

Counsel

Counsel badge from GNU-devel ELPA Counsel badge from GNU ELPA Counsel badge from MELPA Counsel badge from MELPA Stable

ivy-mode ensures that any Emacs command invoking completing-read or completion-in-region will use Ivy for completion.

Counsel takes this further, providing versions of common Emacs commands that are customized to make the best use of Ivy. For example, counsel-find-file has some additional keybindings. Pressing DEL will move you to the parent directory.

Enabling counsel-mode remaps built-in Emacs functions that have Counsel replacements:

Emacs command Counsel counterpart
execute-extended-command counsel-M-x
describe-bindings counsel-descbinds
describe-function counsel-describe-function
describe-variable counsel-describe-variable
describe-symbol counsel-describe-symbol
apropos-command counsel-apropos
describe-face counsel-describe-face
list-faces-display counsel-faces
find-file counsel-find-file
find-library counsel-find-library
imenu counsel-imenu
load-library counsel-load-library
load-theme counsel-load-theme
yank-pop counsel-yank-pop
info-lookup-symbol counsel-info-lookup-symbol
pop-to-mark-command counsel-mark-ring
bookmark-jump counsel-bookmark

Installation

Install the counsel package from GNU ELPA or MELPA.

Swiper

Swiper badge from GNU-devel ELPA Swiper badge from GNU ELPA Swiper badge from MELPA Swiper badge from MELPA Stable

Swiper is an alternative to Isearch that uses Ivy to show an overview of all matches.

A Helm version of Swiper is also available: swiper-helm.

Installation

Install the swiper package from GNU ELPA or MELPA.

Screenshots

Screenshot of Swiper in Emacs

There's also a ~ten minute video demo.

Frequently asked questions

  • Q: How do I enter an input that matches one of the candidates instead of this candidate? Example: create a file bar when a file barricade exists in the current directory.

  • A: Press C-M-j. Alternatively, you can make the prompt line selectable with:

    (setopt ivy-use-selectable-prompt t)

Contributing

Please see the guidelines for reporting issues and opening pull requests.

About

Ivy - a generic completion frontend for Emacs, Swiper - isearch with an overview, and more. Oh, man!

Topics

Resources

Stars

Watchers

Forks

Sponsor this project

  •  

Packages

No packages published