Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mkropat/vim-uniformity
Safely make whitespace across your project consistent
https://github.com/mkropat/vim-uniformity
vim whitespace
Last synced: 2 months ago
JSON representation
Safely make whitespace across your project consistent
- Host: GitHub
- URL: https://github.com/mkropat/vim-uniformity
- Owner: mkropat
- License: mit
- Created: 2016-01-06T07:04:47.000Z (about 9 years ago)
- Default Branch: master
- Last Pushed: 2016-01-28T04:00:02.000Z (almost 9 years ago)
- Last Synced: 2024-08-03T01:39:46.025Z (6 months ago)
- Topics: vim, whitespace
- Language: VimL
- Homepage:
- Size: 10.7 KB
- Stars: 12
- Watchers: 3
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE.txt
Awesome Lists containing this project
README
# uniformity.vim
*Safely make whitespace across your project consistent*
__uniformity.vim__ is a tool for batch updating whitespace across a project.
Because it's a batch tool intended to be run infrequently, it may be of use to
you [even if you don't normally use Vim](#why-vim).By whitespace, I'm talking about changing indentation:
- 2-spaces to 4-spaces
- 4-spaces to 2-spaces
- Spaces to tabs
- Anything to anything reallyBut I'm also talking about:
- Stripping traililng whitespace
- Stripping zero-width Unicode characters
- [Changing line
endings](http://vimdoc.sourceforge.net/htmldoc/options.html#'fileformat')
(Windows → *nix, *nix → Windows, etc.)
- [Changing the file
encoding](http://vimdoc.sourceforge.net/htmldoc/options.html#'fileencoding')
- Adding or removing the [UTF
BOM](https://en.wikipedia.org/wiki/Byte_order_mark)### Is uniformity.vim right for you?
Depending on what you're trying to do, __there's a decent chance you don't even
need uniformity.vim__:- Do you want to change what whitespace Vim uses for any new files you create?
Take a look at the [built-in Vim
settings](http://vim.wikia.com/wiki/Indenting_source_code)
- Do you want Vim to re-indent your files [based on what it thinks your code
should look
like](http://vimdoc.sourceforge.net/htmldoc/indent.html#C-indenting)? Try
[`gg=G`](http://vim.wikia.com/wiki/Fix_indentation).
- Do you want to change both leading and non-leading whitespace in the file?
Try [this trick](http://stackoverflow.com/a/16892086/27581).On the other hand...
Do you want to conservatively change whitespace so that only leading
indentation is changed (to minimize the risk of messing up formatting)?
__uniformity.vim__ might be the right tool for the job.While batch updating indentation across a project, do you want to also strip
trailing whitespace, convert line endings, and convert all the files to a
single encoding? __uniformity.vim__ might be the right tool for the job.### Getting Started
#### Pre-requisites
__uniformity.vim__ requires that the
[__sleuth.vim__](https://github.com/tpope/vim-sleuth) plugin be installed.
This is necessary because __uniformity.vim__ relies on the
[`shiftwidth`](http://vimdoc.sourceforge.net/htmldoc/options.html#'shiftwidth')
setting of the buffer to reflect the current indentation of the file so it can
know how to change each line.#### Installation
You'll want to use a plugin manager. The instructions assume you're using
[__vim-plug__](https://github.com/junegunn/vim-plug).Include the following lines in your
[`.vimrc`](http://vim.wikia.com/wiki/Open_vimrc_file):```viml
call plug#begin('~/.vim/plugged')Plug 'tpope/vim-sleuth'
Plug 'mkropat/vim-uniformity'call plug#end()
```Restart Vim, then run `:PlugInstall` to complete the installation.
#### Configuration
Include the following lines in your
[`.vimrc`](http://vim.wikia.com/wiki/Open_vimrc_file):```viml
let g:uniformity_indent = ' '
let g:uniformity_strip_trailing_whitespace = 1
let g:uniformity_strip_zerowidth_chars = 0
let g:uniformity_bomb = 0
let g:uniformity_fileencoding = 'utf-8'
let g:uniformity_fileformat = 'unix'
```Change each setting as desired. You may omit any setting to have it not take
effect. After you're satisfied, load in the settings by restarting Vim or by
running [`:source
%`](http://vimdoc.sourceforge.net/htmldoc/repeat.html#:source).Here's the full reference of what each option does:
Setting | Description
-----------------------------------------|----------------------
`g:uniformity_indent` | The string that represents one level of desired indentation, such as a string that contains 2-spaces, 4-spaces, or a tab character. (To insert a tab character, you can use [this trick](http://stackoverflow.com/a/4781099/27581).)
`g:uniformity_strip_trailing_whitespace` | If set to `1`, [trailing whitespace](http://blog.codinghorror.com/whitespace-the-silent-killer/) will be stripped
`g:uniformity_strip_zerowidth_chars` | If set to `1`, [zero-width Unicode characters](http://stackoverflow.com/a/11305926/27581) will be stripped
`g:uniformity_bomb` | What to set [`'bomb'`](http://vimdoc.sourceforge.net/htmldoc/options.html#'bomb') to
`g:uniformity_fileencoding` | What to set [`'fileencoding'`](http://vimdoc.sourceforge.net/htmldoc/options.html#'fileencoding') to
`g:uniformity_fileformat` | What to set [`'fileformat'`](http://vimdoc.sourceforge.net/htmldoc/options.html#'fileformat') to#### Usage
To update the whitespace formatting in a single file, run:
:Uniform
If the changes look good, save the file:
:update
To update all the files in a project, we can use
[`:argdo`](http://vimdoc.sourceforge.net/htmldoc/editing.html#:argdo). First
[`:lcd`](http://vimdoc.sourceforge.net/htmldoc/editing.html#:lcd) to the
project directory, then add all the files you're interested to the [*argument
list*](http://vimdoc.sourceforge.net/htmldoc/editing.html#argument-list) with
something like::args **\*.c **\*.h
(Replace `*.c` and `*.h` with the extensions of the files that you are
interested in.)To incrementally build up the *argument list*, check out
[`:argadd`](http://vimdoc.sourceforge.net/htmldoc/editing.html#:argadd). To
exclude specific files or directories, check out
[`:argdelete`](http://vimdoc.sourceforge.net/htmldoc/editing.html#:argdelete).
You can view the contents of the *argument list* at any time by running
[`:args`](http://vimdoc.sourceforge.net/htmldoc/editing.html#:args).Once you are satisifed that the *argument list* contains all the files you want
to act on, run::argdo Uniform
:argdo updateThese commands will run through every file in the *argument list*, update the
whitespace in every file, then save all the files.__Tip__: if you have a lot of files and you don't want to be prompted after
every screenful of results, try [`:set
nomore`](http://vimdoc.sourceforge.net/htmldoc/options.html#'more')If you find `:argdo` cumbersome, you could also try
[`:bufdo`](http://vimdoc.sourceforge.net/htmldoc/windows.html#:bufdo),
[`:tabdo`](http://vimdoc.sourceforge.net/htmldoc/tabpage.html#:tabdo) or
[`:windo`](http://vimdoc.sourceforge.net/htmldoc/windows.html#:windo). Or
better yet, write a plugin that does it better and I will gladly update this
README to point to it.### Notes
#### Why Vim?
When writing a tool for batch processing a bunch of files, I typically don't
reach for a graphical/visual app like Vim as my first choice. However, Vim
offers so much needed functionality out-of-the-box, [I can't imagine a simpler
way to get the same
functionality](https://github.com/mkropat/vim-uniformity/blob/master/autoload/uniformity.vim):- Vim has tried-and-true support for loading in files in any number of combinations of line endings and file encodings
- Vim has a workable, albeit clunky, means for working with all the files in a project (`:argdo`, etc.)
- With [__sleuth.vim__](https://github.com/tpope/vim-sleuth), Vim has a tested library for auto-detecting the indentation settings of a file
- Vim works cross-platform