doomemacs/modules/completion/ivy/README.org

192 lines
7.3 KiB
Org Mode
Raw Normal View History

2019-01-03 15:12:50 +08:00
#+TITLE: completion/ivy
#+DATE: February 13, 2017
#+SINCE: v2.0
#+STARTUP: inlineimages
* Table of Contents :TOC_3:noexport:
- [[#description][Description]]
- [[#module-flags][Module Flags]]
- [[#plugins][Plugins]]
- [[#hacks][Hacks]]
- [[#prerequisites][Prerequisites]]
- [[#install][Install]]
- [[#macos][MacOS]]
- [[#arch-linux][Arch Linux]]
- [[#opensuse][openSUSE]]
- [[#features][Features]]
- [[#jump-to-file-project-navigation][Jump-to-file project navigation]]
- [[#project-search--replace][Project search & replace]]
- [[#in-buffer-searching][In-buffer searching]]
- [[#ivy-integration-for-various-completing-commands][Ivy integration for various completing commands]]
- [[#general][General]]
- [[#jump-to-files-buffers-or-projects][Jump to files, buffers or projects)]]
- [[#search][Search]]
- [[#configuration][Configuration]]
- [[#enable-fuzzynon-fuzzy-search-for-specific-commands][Enable fuzzy/non-fuzzy search for specific commands]]
- [[#change-the-position-of-the-ivy-childframe][Change the position of the ivy childframe]]
- [[#troubleshooting][Troubleshooting]]
2019-01-03 15:12:50 +08:00
* Description
This module provides Ivy integration for a variety of Emacs commands, as well as
a unified interface for project search and replace, powered by ripgrep.
2017-05-10 20:14:10 +08:00
2017-08-22 02:07:07 +08:00
#+begin_quote
I prefer ivy over ido for its flexibility. I prefer ivy over helm because it's
2019-01-03 15:12:50 +08:00
lighter, simpler and faster in many cases.
2017-08-22 02:07:07 +08:00
#+end_quote
2017-05-26 02:08:50 +08:00
2019-01-03 15:12:50 +08:00
** Module Flags
+ =+fuzzy= Enables fuzzy completion for Ivy searches.
+ =+prescient= Enables prescient filtering and sorting for Ivy searches.
2019-01-03 15:12:50 +08:00
+ =+childframe= Causes Ivy to display in a floating child frame, above Emacs.
+ =+icons= Enables file icons for switch-{buffer,project}/find-file counsel
commands.
2019-01-03 15:12:50 +08:00
** Plugins
+ [[https://github.com/abo-abo/swiper][ivy]]
+ [[https://github.com/abo-abo/swiper][counsel]]
+ [[https://github.com/ericdanan/counsel-projectile][counsel-projectile]]
+ [[https://github.com/abo-abo/swiper][swiper]]
+ [[https://github.com/abo-abo/swiper][ivy-hydra]]
+ [[https://github.com/yevgnen/ivy-rich][ivy-rich]]
+ [[https://github.com/mhayashi1120/Emacs-wgrep][wgrep]]
+ [[https://github.com/DarwinAwardWinner/amx][amx]]
+ [[https://github.com/lewang/flx][flx]]* (=+fuzzy=)
+ [[https://github.com/raxod502/prescient.el][prescient]]* (=+prescient=)
2019-01-03 15:12:50 +08:00
+ [[https://github.com/tumashu/ivy-posframe][ivy-posframe]]* (=+childframe=)
+ [[https://github.com/asok/all-the-icons-ivy][all-the-icons-ivy]]* (=+icons=)
2017-05-10 20:14:10 +08:00
2019-01-03 15:12:50 +08:00
** Hacks
+ Functions with ivy/counsel equivalents have been globally remapped (like
~find-file~ => ~counsel-find-file~). So a keybinding to ~find-file~ will
invoke ~counsel-find-file~ instead.
+ ~counsel-[arp]g~'s 3-character limit was reduced to 1 (mainly for the ex
command)
2017-08-22 02:07:07 +08:00
2019-01-03 15:12:50 +08:00
* Prerequisites
This module depends on:
2019-01-03 15:12:50 +08:00
+ [[https://github.com/BurntSushi/ripgrep][ripgrep]] (rg)
2017-05-10 20:14:10 +08:00
2019-01-03 15:12:50 +08:00
** Install
*** MacOS
#+BEGIN_SRC sh
brew install ripgrep
2019-01-03 15:12:50 +08:00
#+END_SRC
2017-05-10 20:14:10 +08:00
2019-01-03 15:12:50 +08:00
*** Arch Linux
#+BEGIN_SRC sh :dir /sudo::
sudo pacman --needed --noconfirm -S ripgrep
2019-01-03 15:12:50 +08:00
#+END_SRC
2017-05-10 20:14:10 +08:00
*** openSUSE
#+BEGIN_SRC sh :dir /sudo::
sudo zypper install ripgrep
#+END_SRC
2019-01-03 15:12:50 +08:00
* Features
Ivy and its ilk are large plugins. Covering everything about them is outside of
this documentation's scope, so only Doom-specific Ivy features are listed here:
2017-05-10 20:14:10 +08:00
2017-08-22 02:07:07 +08:00
** Jump-to-file project navigation
2019-01-03 15:12:50 +08:00
Inspired by Sublime Text's jump-to-anywhere, CtrlP/Unite in Vim, and Textmate's
Command-T, this module provides similar functionality by bringing ~projectile~
and ~ivy~ together.
2019-01-03 15:12:50 +08:00
https://assets.doomemacs.org/completion/ivy/projectile.png
2017-05-10 20:14:10 +08:00
2019-01-03 15:12:50 +08:00
| Keybind | Description |
|----------------------+-------------------------------------|
| =SPC p f=, =SPC SPC= | Jump to file in project |
| =SPC f f=, =SPC .= | Jump to file from current directory |
2017-05-10 20:14:10 +08:00
2019-01-03 15:12:50 +08:00
** Project search & replace
This module provides interactive text search and replace using ripgrep.
2019-01-03 15:12:50 +08:00
| Keybind | Description |
|-----------+---------------------------------|
| =SPC s b= | Search the current buffer |
| =SPC s p= | Search project |
| =SPC s d= | Search this directory |
| =SPC p t= | List all TODO/FIXMEs in project |
2019-01-03 15:12:50 +08:00
https://assets.doomemacs.org/completion/ivy/search.png
The universal argument (=SPC u= for evil users; =C-u= otherwise) changes the
behavior of these commands, instructing the underlying search engine to include
ignored files.
This module also provides Ex Commands for evil users:
| Ex command | Description |
|------------------------+------------------------------------------------------------------|
| ~:pg[rep][!] [QUERY]~ | Search project (if ~!~, include hidden files) |
| ~:pg[rep]d[!] [QUERY]~ | Search from current directory (if ~!~, don't search recursively) |
2019-01-03 15:12:50 +08:00
The optional BANG functions is equivalent to the universal argument for the
previous commands.
-----
While in a search these extra keybindings are available to you:
2017-05-10 20:14:10 +08:00
| Keybind | Description |
|-----------+-----------------------------------------------|
| =C-c C-e= | Open a writable buffer of your search results |
| =C-SPC= | Preview the current candidate |
| =M-RET= | Open the selected candidate in other-window |
2017-05-10 20:14:10 +08:00
Changes to the resulting wgrep buffer (opened by =C-c C-e=) can be committed
with =C-c C-c= and aborted with =C-c C-k= (alternatively =ZZ= and =ZQ=, for evil
users).
2017-05-10 20:14:10 +08:00
2019-01-03 15:12:50 +08:00
https://assets.doomemacs.org/completion/ivy/search-replace.png
2017-05-10 20:14:10 +08:00
2019-01-03 15:12:50 +08:00
** In-buffer searching
The =swiper= package provides an interactive buffer search powered by ivy. It
can be invoked with:
+ =SPC s s=
+ =SPC s S= (uses thing at point as initial input)
2019-01-03 15:12:50 +08:00
+ ~:sw[iper] [QUERY]~
2017-05-10 20:14:10 +08:00
2019-01-03 15:12:50 +08:00
https://assets.doomemacs.org/completion/ivy/swiper.png
2017-05-10 20:14:10 +08:00
A wgrep buffer can be opened from swiper with =C-c C-e=.
2019-01-03 15:12:50 +08:00
** Ivy integration for various completing commands
*** General
| Keybind | Description |
|----------------+---------------------------|
| =M-x=, =SPC := | Smarter, smex-powered M-x |
| =SPC '= | Resume last ivy session |
*** Jump to files, buffers or projects)
| Keybind | Description |
|----------------------+---------------------------------------|
| =SPC RET= | Find bookmark |
| =SPC f f=, =SPC .= | Browse from current directory |
| =SPC p f=, =SPC SPC= | Find file in project |
| =SPC f r= | Find recently opened file |
| =SPC p p= | Open another project |
| =SPC b b=, =SPC ,= | Switch to buffer in current workspace |
| =SPC b B=, =SPC <= | Switch to buffer |
2019-01-03 15:12:50 +08:00
*** Search
| Keybind | Description |
|-----------+-------------------------------------------|
| =SPC p t= | List all TODO/FIXMEs in project |
| =SPC s b= | Search the current buffer |
| =SPC s d= | Search this directory |
| =SPC s D= | Search another directory |
| =SPC s i= | Search for symbol in current buffer |
| =SPC s p= | Search project |
| =SPC s P= | Search another project |
| =SPC s s= | Search the current buffer (incrementally) |
2019-01-03 15:12:50 +08:00
* Configuration
** TODO Enable fuzzy/non-fuzzy search for specific commands
** TODO Change the position of the ivy childframe
* TODO Troubleshooting