Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/tedkulp/vim-config

My vim configuration. It's a WIP.
https://github.com/tedkulp/vim-config

Last synced: 2 days ago
JSON representation

My vim configuration. It's a WIP.

Awesome Lists containing this project

README

        

# Ted's custom vim config #

It's a work in progress. Below is a list of key bindings and notes.
The layout and some configurations are based on the [EdgeCase vim
configuration](https://github.com/edgecase/vim-config). I've pulled
the basic directory layout and Vundle setup, but kept most of my
plugin choices and keymaps.

Below is a list of plugin descriptions and keymap changes.

## Setup ##

1. `git clone git://github.com/tedkulp/vim-config.git`
2. `cd vim-config`
3. `sh setup.sh`

_Note_: You can rerun the script again and it will update all the plugins
to their latest releases.

## Custom Shortcuts ##

* `c-h` Move left one window/buffer
* `c-j` Move down one window/buffer
* `c-k` Move up one window/buffer
* `c-l` Move right one window/buffer
* `s-up` Resize buffer one line higher
* `s-down` Resize buffer one line lower
* `s-left` Resize buffer one column smaller
* `s-right` Resize buffer one column bigger
* `w` Enable word wrapping
* `W` Disable word wrapping
* `c` Remove trailing whitespace on whole file
* `space` Remove search highlight
* `I` Reindent entire file
* `ss` Save all buffers/open files
* `Ba` Delete all buffers (cap B so it doesn't slow down Buffergator)
* `F8` Toggle paste when in Insert mode
* `F9` Toggle between light and dark background mode

## YankRing ##

Vim does not provide any mechanism to reference previous yanked, deleted
or changed text. In Emacs this feature is called the "kill ring".

The YankRing plugin allows the user to configure the number of yanked,
deleted and changed text. A split window can be used to choose which
element(s) from the yankring you wish to paste. Alternately after
text has been pasted (using p), it can be replaced with a previous
value from the yankring with a single key stroke. You can learn more
about it with `:help yankring`.

**Cheatsheet**:

* `c-p` to move backwards through the ring
* `c-n` to move forwards through the ring
* `:YRShow` Show the current ring

## "Project Drawer" aka NERDTree ##

NERDTree is a file explorer plugin that provides "project drawer"
functionality to your vim projects. You can learn more about it with
`:help NERDTree`.

**Cheatsheet**:

Use `m` on any selected file/dir to bring up a menu of file commands

**Customizations**:

Use `gt` to toggle NERDTree

## NERDCommenter ##

A plugin that allows for easy commenting of code for many filetypes.
Use `:help nerdcommenter`

**Cheatsheet**:

* `cc` - Comment out the current line or text selected in visual mode.
* `cn` - Same as cc but forces nesting.
* `c` - Toggles the comment state of the selected line(s).
If the topmost selected line is commented, all selected lines are uncommented
and vice versa.
* `ci` - Toggles the comment state of the selected line(s) individually.
* `cs` - Comments out the selected lines "sexily"

There are lots more... look at the help

## Ack.vim ##

Ack.vim uses ack to search inside the current directory for a pattern.
You can learn more about it with :help Ack

**Customizations**:

`g/` to bring up `:Ack `.

## Repeat.vim ##

If you've ever tried using the `.` command after a plugin map, you were likely disappointed to discover it only repeated the last native command inside that map, rather than the map as a whole. That disappointment ends today. Repeat.vim remaps `.` in a way that plugins can tap into it.

The following plugins support repeat.vim:

* surround.vim _(installed)_
* abolish.vim _(installed)_
* unimpaired.vim _(installed)_
* speeddating.vim
* commentary.vim

## indent-object ##

Indent object creates a "text object" that is relative to the current
ident. Text objects work inside of visual mode, and with `c` (change),
`d` (delete) and `y` (yank). For instance, try going into a method in
normal mode, and type `v ii`. Then repeat `ii`.

**Cheatsheet**:

* `ai` - (A)n (I)ndentation level and line above.
* `ii` - (I)nner (I)ndentation level (no line above).
* `aI` - (A)n (I)ndentation level and lines above/below.
* `iI` - (I)nner (I)ndentation level (no lines above/below).

## text-object-ruby-block ##

When textobj-rubyblock is installed you will gain two new text objects,
which are triggered by `ar` and `ir` respectively. These follow Vim convention,
so that `ar` selects all of a ruby block, and `ir` selects the inner portion
of a rubyblock.

In ruby, a block is always closed with the end keyword. Ruby blocks may
be opened using one of several keywords, including module, class, def, if,
and do.

## [Surround](https://github.com/tpope/vim-surround) ##

Surround allows you to modify "surroundings" around the current text.
For instance, if the cursor was inside `"foo bar"`, you could type
`cs"'` to convert the text to `'foo bar'`.

There's a lot more; check it out at `:help surround`

**Cheatsheet**:

* `cs"'` - Change `"Hello World"` to `'Hello World'`
* `cs'` - Change `'Hello World'` to `Hello World`
* `cst"` - Change `Hello World` to `"Hello World"`
* `ds"` - Remove delimiters from `"Hello World"`
* `ysiw]` - Makes `[Hello] World!` (w/ cursor on Hello -- iw is 'word' text object)
* `ds]` - Makes `Hello World!` (w/ cursor on Hello)
* `S(` - Visual mode -- wraps selected text in ( and )

## [Ctrl-P](https://github.com/kien/ctrlp.vim) ##

Provides convenient ways to quickly reach the buffer or file you want.

* `` - fuzzy find files
* `` - open selected item in window in horizontal split
* `` - open selected item in vertical split
* `` - open selected item in a new tab
* `` / `` - cycle between file, buffer, MRU and "both" modes
* `` - purge the cache for the current directory

## [Fugitive](https://github.com/tpope/vim-fugitive) ##

I'm not going to lie to you; fugitive.vim may very well be the best
Git wrapper of all time. Check out these features:

View any blob, tree, commit, or tag in the repository with `:Gedit` (and
`:Gsplit`, `:Gvsplit`, `:Gtabedit`, ...). Edit a file in the index and
write to it to stage the changes. Use `:Gdiff` to bring up the staged
version of the file side by side with the working tree version and use
Vim's diff handling capabilities to stage a subset of the file's
changes.

Bring up the output of `git status` with `:Gstatus`. Press `-` to
`add`/`reset` a file's changes, or `p` to `add`/`reset` `--patch` that
mofo. And guess what `:Gcommit` does!

`:Gblame` brings up an interactive vertical split with `git blame`
output. Press enter on a line to reblame the file as it stood in that
commit, or `o` to open that commit in a split. When you're done, use
`:Gedit` in the historic buffer to go back to the work tree version.

`:Gmove` does a `git mv` on a file and simultaneously renames the
buffer. `:Gremove` does a `git rm` on a file and simultaneously deletes
the buffer.

Use `:Ggrep` to search the work tree (or any arbitrary commit) with
`git grep`, skipping over that which is not tracked in the repository.
`:Glog` loads all previous revisions of a file into the quickfix list so
you can iterate over them and watch the file evolve!

`:Gread` is a variant of `git checkout -- filename` that operates on the
buffer rather than the filename. This means you can use `u` to undo it
and you never get any warnings about the file changing outside Vim.
`:Gwrite` writes to both the work tree and index versions of a file,
making it like `git add` when called from a work tree file and like
`git checkout` when called from the index or a blob in history.

Use `:Gbrowse` to open the current file on GitHub, with optional line
range (try it in visual mode!). If your current repository isn't on
GitHub, `git instaweb` will be spun up instead.

Add `%{fugitive#statusline()}` to `'statusline'` to get an indicator
with the current branch in (surprise!) your statusline.

Oh, and of course there's `:Git` for running any arbitrary command.

**Customizations**:

* Binds `gb` to `:Gblame`
* Binds `gs` to `:Gstatus`
* Binds `gd` to `:Gdiff`
* Binds `gl` to `:Glog`
* Binds `gc` to `:Gcommit`
* Binds `gp` to `:Git push`

## [ZoomWin](http://github.com/vim-scripts/ZoomWin) ##

When working with split windows, ZoomWin lets you zoom into a window and
out again using ` o`

**Customizations**:

* Binds `z` to `:ZoomWin`

## [Bufexplorer](http://www.vim.org/scripts/script.php?script_id=42) ##

With bufexplorer, you can quickly and easily switch between buffers by using
the one of the default public interfaces:

`be` (normal open) or
`bs` (force horizontal split open) or
`bv` (force vertical split open)

Once the bufexplorer window is open you can use the normal movement keys (hjkl)
to move around and then use `` or `` to select the
buffer you would like to open. If you would like to have the selected buffer
opened in a new tab, simply press either `` or `t`. Please note
that when opening a buffer in a tab, that if the buffer is already in another
tab, bufexplorer can switch to that tab automatically for you if you would
like. More about that in the supplied VIM help.

## [EasyMotion](https://github.com/Lokaltog/vim-easymotion) ##

EasyMotion provides a much simpler way to use some motions in vim. It takes the
out of w or f{char} by highlighting all possible choices and allowing you to
press one key to jump directly to the target.

When one of the available motions is triggered, all visible text preceding or
following the cursor is faded, and motion targets are highlighted.

EasyMotion is triggered by one of the provided mappings.

check EasyMotion's [home page](https://github.com/Lokaltog/vim-easymotion) for more information.

## [Supertab](https://github.com/ervandew/supertab) ##

Supertab aims to provide tab completion to satisfy all your insert completion
needs (:help ins-completion).

**Customizations**:

* __(switch tab and c-tab)__
* Binds `` to `g:SuperTabMappingTabLiteral`
* Binds `` to `g:SuperTabMappingForward`

## [BufOnly](http://www.vim.org/scripts/script.php?script_id=1071) ##

`:BufOnly` without an argument will unload all buffers but the current one. `:BufOnly`
with an argument will close all buffers but the supplied buffer name/number.

**Customizations**:

* Binds `Bo` to `:BufOnly` (cap B so it doesn't slow down Buffergator)

## [Tagbar](https://github.com/majutsushi/tagbar) ##

Tagbar is a vim plugin for browsing the tags of source code files.

**Customizations**:

* Binds `t` to toggle Tagbar

## [Powerline](https://github.com/Lokaltog/vim-powerline) ##

Powerline is a utility plugin which allows you to create better-looking, more
functional vim statuslines.

_(I have some customizations for this, but let them out of the repo, as they're
fairly machine specific)_

## [vimux](https://github.com/benmills/vimux) ##

Easily interact with tmux from vim. This project is still in development, so
some features are still missing.

**Customizations**:

* `rb` - Run the current file with rspec
* `rp` - Prompt for a command to run
* `rl` - Run last command executed by RunVimTmuxCommand
* `ri` - Inspect runner pane
* `rx` - Close all other tmux panes in current window
* `rs` - Interrupt any command running in the runner pane

## [Abolish](https://github.com/tpope/vim-abolish) ##

_(I just copied the whole README -- it's too hard to explain)_

This is a plugin over 3 years in the making that I've deferred releasing, primarily
because it's so gosh darn hard to explain. It's three superficially unrelated
plugins in one that share a common theme: working with variants of a word.

### Abbreviation ###

I know how to spell separate. I know how to spell desperate. My fingers, however, have trouble
distinguishing between the two, and I invariably have a 50 percent chance of typing
seperate or desparate each time one of these comes up. At first, I tried abbreviations:

iabbrev seperate separate
iabbrev desparate desperate

But this falls short at the beginning of a sentence.

iabbrev Seperate Separate
iabbrev Desparate Desperate

To be really thorough, we need uppercase too!

iabbrev SEPERATE SEPARATE
iabbrev DESPARATE DESPERATE

Oh, but consider the noun form, and the adverb form!

iabbrev seperation separation
iabbrev desparation desperation
iabbrev seperately separately
iabbrev desparately desperately
iabbrev Seperation separation
iabbrev Desparation Desperation
iabbrev Seperately Separately
iabbrev Desparately Desperately
iabbrev SEPERATION SEPARATION
iabbrev DESPARATION DESPERATION
iabbrev SEPERATELY SEPARATELY
iabbrev DESPARATELY DESPERATELY

Wait, there's also separates, separated, separating, separations, separator...

Abolish.vim provides a simpler way. The following one command produces 48 abbreviations
including all of the above.

Abolish {despa,sepe}rat{e,es,ed,ing,ely,ion,ions,or} {despe,sepa}rat{}

My current configuration has 25 Abolish commands that create hundreds of corrections
my fingers refuse to learn.

### Substitution ###

One time I had an application that with a domain model called "facilities" that needed
to be renamed to "buildings". So, a simple search and replace, right?

:%s/facility/building/g

Oh, but the case variants!

:%s/Facility/Building/g
:%s/FACILITY/BUILDING/g

Wait, the plural is more than "s" so we need to get that too!

:%s/facilities/buildings/g
:%s/Facilities/Buildings/g
:%s/FACILITIES/BUILDINGS/g

Abolish.vim has your back. One command to do all six, and you can repeat it with & too!

:%Subvert/facilit{y,ies}/building{,s}/g

You can abbreviate it as :S, and it accepts the full range of flags including
things like c (confirm).

There's also a variant for searching and a variant for grepping.

### Coercion ###

Want to turn fooBar into foo_bar? Press crs (coerce to snake_case).
MixedCase, camelCase, snake_case, and UPPER_CASE are all just 3 keystrokes
away. These commands support repeat.vim.