Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/cookiengineer/dotvim
:beers: My very own VIM config. It's the very bestest in the galaxy. Towel included.
https://github.com/cookiengineer/dotvim
dotfiles vim vim-configuration
Last synced: 3 months ago
JSON representation
:beers: My very own VIM config. It's the very bestest in the galaxy. Towel included.
- Host: GitHub
- URL: https://github.com/cookiengineer/dotvim
- Owner: cookiengineer
- Created: 2016-06-16T20:48:16.000Z (over 8 years ago)
- Default Branch: master
- Last Pushed: 2023-06-19T09:05:31.000Z (over 1 year ago)
- Last Synced: 2024-08-01T12:33:46.699Z (6 months ago)
- Topics: dotfiles, vim, vim-configuration
- Language: Vim Script
- Homepage: http://cookie.engineer
- Size: 1.04 MB
- Stars: 11
- Watchers: 3
- Forks: 1
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
Awesome Lists containing this project
README
## Cookie's VIM config
This is my personal VIM config, I like it very much.
The configuration is split up in multiple `.vim` files,
so everything looks nice and clean (and maybe even
modular).It is verified to work on these systems:
- `vim` on GNU/Linux in GNOME terminal or kitty
- `vim` on Termux for Android
- `MacVIM` on MacOS## Installation
If you want this VIM config, do this in your Terminal:
```bash
mv ~/.vim ~/.vim__NOTSOAWESOME;
mv ~/.vimrc ~/.vimrc__NOTSOAWESOME;git clone https://github.com/cookiengineer/dotvim ~/.vim;
ln -s ~/.vim/.vimrc ~/.vimrc;
```The plugins are contained in [./plugged](./plugged) and are
statically shipped in this repository (for the sake of having
a known-to-work-failsafe history).For details on plugins and how to update, read **Plugins**
and **Updates** respectively down below.## Usage
### Auto Fixes
- Copy/Paste from GUI applications into Terminal
- Copy/Paste leads to auto-indented code### Auto Commands
Auto commands are defined in [autocmds.vim](./autocmds.vim).
- `BufWritePre` removes trailing whitespaces.
- `BufWritePre` and `FileWritePre` creates non-existing parent folder paths via `mkdir -p`.
- `FileChangedRO`, `FileChangedShell`, `FileChangedShellPost` have been modified to echo the warning instead of opening an annoying shell.### Manual Commands
- `:W` will write files with `sudo` / `root` rights.
### Normal Mode
Key Bindings that don't require a plugin are defined in [mappings.vim](./mappings.vim),
those that do are defined in the `settings..vim` file.- `[F1]` opens `netrw` as sidebar.
- `[F2]` turns off highlighting (`/` in normal mode).
- `[F3]` formats, auto-indents and auto-lints the current buffer.
- `[+]` (`[Shift] + [-]` on US keyboard) toggles current window zoom (aka fullscreen mode).
- `[p]` auto formats bad indents on paste.**Tab Navigation**
- `[Ctrl] + [E], [S]` creates a new tab.
- `[Ctrl] + [E], [V]` creates a new tab.
- `[Ctrl] + [E], [C]` closes the current tab.
- `[Ctrl] + [E], [Arrow Key]` moves focus to different tab.
- `[Ctrl] + [E], [H/L]` moves focus to different tab.**Window/Buffer Navigation**
(Default Bindings)
- `[Ctrl] + [W], [S]` horizontally splits current window.
- `[Ctrl] + [W], [V]` vertically splits current window.
- `[Ctrl] + [W], [Arrow Key]` moves focus to different window.
- `[Ctrl] + [W], [H/J/K/L]` moves focus to different window.Additional Bindings are defined in [settings.tradewinds.vim](./settings.tradewinds.vim).
- `[Shift] + [W], [Arrow Key]` moves the current window.
- `[Shift] + [W], [H/J/K/L]` moves the current window.**Error Navigation**
Error Navigation Bindings are defined in [settings.ale.vim](./settings.ale.vim).
- `[Ctrl] + [Arrow Key]` moves focus to to different linting error.
- `[Ctrl] + [J/K]` moves focus to different linting error.### Visual Mode
(Default Bindings)
- `[g], [f]` opens File under cursor in current window.
- `[g], [x]` opens Browser or Application via `gio open`.### Normal Mode and Visual Mode
Additional Bindings are defined in [settings.move.vim](./settings.move.vim).
- `[Ctrl] + [J/K]` moves currently selected block.
## Templates
The templates are defined in [templates.vim](./templates.vim)
- `,css` inserts the [default.css](./templates/default.css) template
- `,html` inserts the [default.html](./templates/default.html) template
- `,mjs` inserts the [default.mjs](./templates/default.mjs) template- `,eslintrc` inserts the [eslintrc.json](./templates/eslintrc.json) template
- `,make` inserts the [make.mjs](./templates/make.mjs) template
- `,package` inserts the [package.json](./templates/package.json) template## Plugins
The plugins are defined in [.vimrc](./.vimrc) and use a static copy
of [vim-zen](https://github.com/prakashdanish/vim-zen) located at
[./autoload/zen.vim](./autoload/zen.vim).- [w0rp/ale](https://github.com/w0rp/ale)
- [ervandew/supertab](https://github.com/ervandew/supertab)
- [djoshea/vim-autoread](https://github.com/djoshea/vim-autoread)
- [sgur/vim-editorconfig](https://github.com/sgur/vim-editorconfig)
- [itchyny/lightline.vim](https://github.com/itchyny/lightline.vim)
- [vim-utils/vim-man](https://github.com/vim-utils/vim-man)
- [matze/vim-move](https://github.com/matze/vim-move)
- [andymass/vim-tradewinds](https://github.com/andymass/vim-tradewinds)### Updates
The `zen.vim` file is modified to use `git clone --depth=1 --single-branch --branch=master`
in order to save bandwidth. In order to make a full plain copy,
just remove the subfolders in [./plugged](./plugged), do a `:ZenInstall`
via `vim`, and execute the [bin/clean.sh](bin/clean.sh) file afterwards
via `bash`.It is wise to modify the [bin/clean.sh](./bin/clean.sh) when some
unnecessary bloat was added to plugins and appear in a `git diff`
afterwards (Pull Requests welcomed).