Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/justinmk/vim-sneak
The missing motion for Vim :athletic_shoe:
https://github.com/justinmk/vim-sneak
motion navigation neovim neovim-plugin nvim plugin vim vim-plugin viml
Last synced: 7 days ago
JSON representation
The missing motion for Vim :athletic_shoe:
- Host: GitHub
- URL: https://github.com/justinmk/vim-sneak
- Owner: justinmk
- License: mit
- Created: 2013-09-21T16:26:40.000Z (about 11 years ago)
- Default Branch: master
- Last Pushed: 2024-02-21T20:11:07.000Z (10 months ago)
- Last Synced: 2024-11-28T18:01:24.321Z (14 days ago)
- Topics: motion, navigation, neovim, neovim-plugin, nvim, plugin, vim, vim-plugin, viml
- Language: Vim Script
- Homepage: http://www.vim.org/scripts/script.php?script_id=4809
- Size: 730 KB
- Stars: 3,280
- Watchers: 23
- Forks: 89
- Open Issues: 21
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- my-awesome-github-stars - justinmk/vim-sneak - The missing motion for Vim :athletic_shoe: (Vim Script)
README
sneak.vim đź‘ź
================Jump to any location specified by two characters.
Sneak is a powerful, reliable, yet minimal _motion_ plugin for Vim. It works with **multiple
lines**, **operators** (including repeat `.` and [surround]), motion-repeat
(`;` and `,`), **[keymaps]**, **visual** mode, **[multibyte]** text, and
**macros**.Try *label-mode* for a minimalist alternative to
[EasyMotion](https://github.com/easymotion/vim-easymotion):```vim
let g:sneak#label = 1
```Usage
-----Sneak is invoked with `s` followed by exactly two characters:
s{char}{char}
* Type `sab` to **move the cursor** immediately to the next instance of the text "ab".
* Additional matches, if any, are highlighted until the cursor is moved.
* Type `;` to go to the next match (or `s` again, if `s_next` is enabled; see [`:help sneak`](doc/sneak.txt)).
* Type `3;` to skip to the third match from the current position.
* Type `ctrl-o` or ``` `` ``` to go back to the starting point.
* This is a built-in Vim motion; Sneak adds to Vim's [jumplist](http://vimdoc.sourceforge.net/htmldoc/motion.html#jumplist)
*only* on `s` invocation—not repeats—so you can
abandon a trail of `;` or `,` by a single `ctrl-o` or ``` `` ```.
* Type `s` at any time to repeat the last Sneak-search.
* Type `S` to search backwards.Sneak can be limited to a **vertical scope** by prefixing `s` with a [count].
* Type `5sxy` to go immediately to the next instance of "xy" within 5 columns
of the cursor.Sneak is invoked with [**operators**](http://vimdoc.sourceforge.net/htmldoc/motion.html#operator)
via `z` (because `s` is taken by surround.vim).* Type `3dzqt` to delete up to the *third* instance of "qt".
* Type `.` to repeat the `3dzqt` operation.
* Type `2.` to repeat twice.
* Type `d;` to delete up to the next match.
* Type `4d;` to delete up to the *fourth* next match.
* Type `yszxy]` to [surround] in brackets up to `xy`.
* Type `.` to repeat the surround operation.
* Type `gUz\}` to upper-case the text from the cursor until the next instance
of the literal text `\}`
* Type `.` to repeat the `gUz\}` operation.Install
-------Requires Vim 7.3+ or [Nvim](https://neovim.io/). Label-mode requires Vim
7.4.792+. With Nvim 0.5+ label-mode is driven by [virtual text](https://neovim.io/doc/user/api.html#nvim_buf_set_extmark())
instead of the legacy "conceal" feature.- [vim-plug](https://github.com/junegunn/vim-plug)
- `Plug 'justinmk/vim-sneak'`
- [Pathogen](https://github.com/tpope/vim-pathogen)
- `git clone git://github.com/justinmk/vim-sneak.git ~/.vim/bundle/vim-sneak`
- Manual installation:
- Copy the files to your `.vim` directory.To repeat Sneak *operations* (like `dzab`) with dot `.`,
[repeat.vim](https://github.com/tpope/vim-repeat) is required.FAQ
---### Why not use `/`?
For the same reason that Vim has [motions](http://vimdoc.sourceforge.net/htmldoc/motion.html#left-right-motions)
like `f` and `t`: common operations should use the fewest keystrokes.* `/ab` requires 33% more keystrokes than `sab`
* Sets *only* the initial position in the Vim jumplist—so you can explore a
trail of matches via `;`, then return to the start with a single `ctrl-o` or ``` `` ```
* Doesn't clutter your search history
* Input is always literal (don't need to escape special characters)
* Ignores accents ("equivalence class") when matching
([#183](https://github.com/justinmk/vim-sneak/issues/183))
* Smarter, subtler highlighting### Why not use `f`?
* 50x more precise than `f` or `t`
* Moves vertically
* Highlights matches in the direction of your search### How dare you remap `s`?
You can specify any mapping for Sneak (see [`:help sneak`](doc/sneak.txt)).
By the way: `cl` is equivalent to `s`, and `cc` is equivalent to `S`.### How can I replace `f` with Sneak?
```vim
map f Sneak_s
map F Sneak_S
```### How can I replace `f` and/or `t` with *one-character* Sneak?
Sneak has `` mappings for `f` and `t` 1-character-sneak.
These mappings do *not* invoke label-mode, even if you have it enabled.```vim
map f Sneak_f
map F Sneak_F
map t Sneak_t
map T Sneak_T
```Related
-------* [Seek](https://github.com/goldfeld/vim-seek)
* [EasyMotion](https://github.com/Lokaltog/vim-easymotion)
* [smalls](https://github.com/t9md/vim-smalls)
* [improvedft](https://github.com/chrisbra/improvedft)
* [clever-f](https://github.com/rhysd/clever-f.vim)
* [vim-extended-ft](https://github.com/svermeulen/vim-extended-ft)
* [Fanf,ingTastic;](https://github.com/dahu/vim-fanfingtastic)
* [IdeaVim-Sneak](https://plugins.jetbrains.com/plugin/15348-ideavim-sneak)
* [leap.nvim](https://github.com/ggandor/leap.nvim)
* [flash.nvim](https://github.com/folke/flash.nvim)License
-------Copyright © Justin M. Keyes. Distributed under the MIT license.
[multibyte]: http://vimdoc.sourceforge.net/htmldoc/mbyte.html#UTF-8
[keymaps]: http://vimdoc.sourceforge.net/htmldoc/mbyte.html#mbyte-keymap
[surround]: https://github.com/tpope/vim-surround
[count]: http://vimdoc.sourceforge.net/htmldoc/intro.html#[count]