Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/booperlv/nvim-gomove
A complete plugin for moving and duplicating blocks and lines, with complete fold handling, reindenting, and undoing in one go.
https://github.com/booperlv/nvim-gomove
neovim neovim-plugin
Last synced: 3 months ago
JSON representation
A complete plugin for moving and duplicating blocks and lines, with complete fold handling, reindenting, and undoing in one go.
- Host: GitHub
- URL: https://github.com/booperlv/nvim-gomove
- Owner: booperlv
- License: mit
- Created: 2021-10-30T12:49:41.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2022-07-19T11:36:41.000Z (over 2 years ago)
- Last Synced: 2024-07-31T20:51:36.944Z (6 months ago)
- Topics: neovim, neovim-plugin
- Language: Lua
- Homepage:
- Size: 85 KB
- Stars: 195
- Watchers: 2
- Forks: 2
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-neovim - booperlv/nvim-gomove - A complete plugin for moving and duplicating blocks and lines, with complete fold handling, reindenting, and undoing in one go. (Editing Support / Scrollbar)
README
# nvim-gomove
A complete plugin for moving and duplicating blocks and lines, with complete fold handling, reindenting, and undoing in one go.
https://user-images.githubusercontent.com/65604882/147652973-62e30299-946d-4924-8766-0366016f70de.mp4
## Requirements
This plugin works with NeoVim v0.5 or later.
## Installation
- [packer.nvim](https://github.com/wbthoason/packer.nvim)
``` lua
use 'booperlv/nvim-gomove'
```- [vim-plug](https://github.com/junegunn/vim-plug)
``` vim
Plug 'booperlv/nvim-gomove'
```- [paq](https://github.com/savq/paq-nvim)
``` lua
'booperlv/nvim-gomove';
```## Why nvim-gomove?
As many may know, mappings such as "ddp", and ":move" already exist as solutions to moving lines. What makes nvim-gomove any different, and what are it's goals?
nvim-gomove actually makes use of these same solutions, but just with a little more on top. It's a wrapper that polishes and tries to make these solutions as complete as possible, by dealing with folds, undoing, trailing whitespaces and reindenting for you.
It may not be for everyone, but it might be helpful for the few that would like it :)
## Features
### Moving and Duplicating (Vertically and Horizontally):
- Lines in Normal Mode
- Lines in Visual Mode
- Blocks in Normal Mode
- Blocks in Visual Mode### With the following additional features:
- Full Fold Handling
- Undoing in one go
- Deleting Trailing Whitespaces (Block Vertical)
- Reindenting## Usage
The default "smart" move mappings work this way:
| Mapping | Normal | Visual | Line-Visual | Block-Visual |
|---------|--------|--------|-------------|--------------|
| \ | Block Left | Block Left | Line Left | Block Left |
| \ | Line Down | Line Down | Line Down | Block Down |
| \ | Line Up | Line Up | Line Up | Block Up |
| \ | Block Right | Block Right | Line Right | Block Right |#### \ duplicates respectively
## Configuration
```lua
require("gomove").setup {
-- whether or not to map default key bindings, (true/false)
map_defaults = true,
-- whether or not to reindent lines moved vertically (true/false)
reindent = true,
-- whether or not to undojoin same direction moves (true/false)
undojoin = true,
-- whether to not to move past end column when moving blocks horizontally, (true/false)
move_past_end_col = false,
}
```## Mappings
While there are default mappings, called "smart mappings" that are designed to
be as intuitive as possible out of the box - that itself is built on "base"
mappings which can serve as a framework for creating your own mappings. Check
gomove/mappings/smart.lua as an example of the usage of the "base" mappings.## Example for Changing Default (Smart) Keybinds:
Just a reminder to set the option `map_defaults = false` in the setup function
```vim
nmap GoNSMLeft
nmap GoNSMDown
nmap GoNSMUp
nmap GoNSMRightxmap GoVSMLeft
xmap GoVSMDown
xmap GoVSMUp
xmap GoVSMRightnmap GoNSDLeft
nmap GoNSDDown
nmap GoNSDUp
nmap GoNSDRightxmap GoVSDLeft
xmap GoVSDDown
xmap GoVSDUp
xmap GoVSDRight
``````lua
local map = vim.api.nvim_set_keymapmap( "n", "", "GoNSMLeft", {} )
map( "n", "", "GoNSMDown", {} )
map( "n", "", "GoNSMUp", {} )
map( "n", "", "GoNSMRight", {} )map( "x", "", "GoVSMLeft", {} )
map( "x", "", "GoVSMDown", {} )
map( "x", "", "GoVSMUp", {} )
map( "x", "", "GoVSMRight", {} )map( "n", "", "GoNSDLeft", {} )
map( "n", "", "GoNSDDown", {} )
map( "n", "", "GoNSDUp", {} )
map( "n", "", "GoNSDRight", {} )map( "x", "", "GoVSDLeft", {} )
map( "x", "", "GoVSDDown", {} )
map( "x", "", "GoVSDUp", {} )
map( "x", "", "GoVSDRight", {} )
```## Smart Mappings:
```
Naming Convention:
Go, Normal/Visual, Smart, Move/Duplicate, Direction
```| Name | Function |
|------|----------|
| Vertical |
| \GoNSM(Up/Down) | Normal Smart Move Up/Down |
| \GoVSM(Up/Down) | Visual Smart Move Up/Down |
| \GoNSD(Up/Down) | Normal Smart Duplicate Up/Down |
| \GoVSD(Up/Down) | Visual Smart Duplicate Up/Down |
| Horizontal |
| \GoNSM(Left/Right) | Normal Smart Move Left/Right |
| \GoVSM(Left/Right) | Visual Smart Move Left/Right |
| \GoNSD(Left/Right) | Normal Smart Duplicate Left/Right |
| \GoVSD(Left/Right) | Visual Smart Duplicate Left/Right |### Functionality is already explained in [Usage](#usage)
## Base Mappings:
```
Naming Convention:
Go, Normal/Visual, Move/Duplicate, Line/Block, Direction
```### Lines:
| Name | Function |
|------|----------|
| Vertical |
| \GoNMLine(Down/Up) | In Normal Mode, Move current line down/up. Moves along folds. |
| \GoNVLine(Down/Up) | In Visual Mode, Move selected lines down/up. Moves along folds. |
| \GoNDLine(Down/Up) | In Normal Mode, Duplicate current line down/up. |
| \GoVDLine(Down/Up) | In Visual Mode, Duplicate selected lines down/up. |
| Horizontal |
| \GoNMLine(Left/Right) | In Normal Mode, Move current line to the left/right by (indent level). |
| \GoVMLine(Left/Right) | In Visual Mode, Move selected lines to the left/right by (indent level). |
| \GoNDLine(Left/Right) | In Normal Mode, Duplicate current line to the left/right. Duplicating left ignores whitespace at the start of the text that it duplicates. |
| \GoVDLine(Left/Right) | In Visual Mode, Duplicate selected lines to the left/right. Duplicating left ignores whitespace at the start of the text that it duplicates. |### Blocks:
| Name | Function |
|------|----------|
| Vertical |
| \GoNMBlock(Down/Up) | In Normal Mode, Move current character down/up. Tries to avoid folds. |
| \GoVMBlock(Down/Up) | In Visual Mode, Move selected characters down/up. Tries to avoid folds. |
| \GoNDBlock(Down/Up) | In Normal Mode, Duplicate current character down/up. Tries to avoid folds. |
| \GoVDBlock(Down/Up) | In Visual Mode, Duplicate selected characters down/up. Tries to avoid folds. |
| Horizontal |
| GoNMBlock(Left/Right) | In Normal Mode, Move current character left/right. |
| GoVMBlock(Left/Right) | In Visual Mode, Move selected characters left/right. |
| GoNDBlock(Left/Right) | In Normal Mode, Duplicate current character left/right. |
| GoVDBlock(Left/Right) | In Visual Mode, Duplicate selected characters left/right. |## Special Mentions
- [matze/vim-move](https://github.com/matze/vim-move), much of the initial work was based on this plugin
- [t9md/vim-textmanip](https://github.com/t9md/vim-textmanip): many features were made possible using this plugin as a reference