vim-flake8 ========== `vim-flake8` is a Vim plugin that runs the currently open file through Flake8, a static syntax and style checker for Python source code. It supersedes both [vim-pyflakes](https://github.com/nvie/vim-pyflakes) and [vim-pep8](https://github.com/nvie/vim-pep8). [Flake8](https://pypi.python.org/pypi/flake8/) is a wrapper around PyFlakes (static syntax checker), PEP8 (style checker) and Ned's MacCabe script (complexity checker). Installation ------------ Make sure you've installed the [flake8](https://pypi.python.org/pypi/flake8/) package. If you use vim >= 8, install this plugin with: ``` mkdir -p ~/.vim/pack/flake8/start/ cd ~/.vim/pack/flake8/start/ git clone https://github.com/nvie/vim-flake8.git ``` Otherwise, install [vim-pathogen](https://github.com/tpope/vim-pathogen) if you're not using it already. Then, simply put the contents of this repository in your `~/.vim/bundle` directory. Usage ----- 1. Open a Python file 2. Press `<F7>` to run `flake8` on it It shows the errors inside a quickfix window, which will allow your to quickly jump to the error locations by simply pressing [Enter]. If any of `g:flake8_show_in_gutter` or `g:flake8_show_in_file` are set to `1`, call: call flake8#Flake8UnplaceMarkers() To remove all markers. No default mapping is provided. Customization ------------- If you don't want to use the `<F7>` key for flake8-checking, simply remap it to another key. It autodetects whether it has been remapped and won't register the `<F7>` key if so. For example, to remap it to `<F3>` instead, use: autocmd FileType python map <buffer> <F3> :call flake8#Flake8()<CR> For flake8 configuration options please consult the following page: http://flake8.pycqa.org/en/latest/user/configuration.html To customize the location of your flake8 binary, set `g:flake8_cmd`: let g:flake8_cmd="/opt/strangebin/flake8000" To customize the location of quick fix window, set `g:flake8_quickfix_location`: let g:flake8_quickfix_location="topleft" To customize the height of quick fix window, set `g:flake8_quickfix_height`: let g:flake8_quickfix_height=7 To customize whether the quickfix window opens, set `g:flake8_show_quickfix`: let g:flake8_show_quickfix=0 " don't show let g:flake8_show_quickfix=1 " show (default) To customize whether the show signs in the gutter, set `g:flake8_show_in_gutter`: let g:flake8_show_in_gutter=0 " don't show (default) let g:flake8_show_in_gutter=1 " show To customize whether the show marks in the file, set `g:flake8_show_in_file`: let g:flake8_show_in_file=0 " don't show (default) let g:flake8_show_in_file=1 " show To customize the number of marks to show, set `g:flake8_max_markers`: let g:flake8_max_markers=500 " (default) To customize the gutter markers, set any of `flake8_error_marker`, `flake8_warning_marker`, `flake8_pyflake_marker`, `flake8_complexity_marker`, `flake8_naming_marker`. Setting one to the empty string disables it. Ex.: let g:flake8_error_marker='EE' " set error marker to 'EE' let g:flake8_warning_marker='WW' " set warning marker to 'WW' let g:flake8_pyflake_marker='' " disable PyFlakes warnings let g:flake8_complexity_marker='' " disable McCabe complexity warnings let g:flake8_naming_marker='' " disable naming warnings To customize the colors used for markers, define the highlight groups, `Flake8_Error`, `Flake8_Warning`, `Flake8_PyFlake`, `Flake8_Complexity`, `Flake8_Naming`: " to use colors defined in the colorscheme highlight link Flake8_Error Error highlight link Flake8_Warning WarningMsg highlight link Flake8_Complexity WarningMsg highlight link Flake8_Naming WarningMsg highlight link Flake8_PyFlake WarningMsg To show the error message of the current line in the ruler, call `flake8#ShowError()`: " add binding to call the function nnoremap <C-K> :call flake8#Flake8ShowError()<cr> Tips ---- A tip might be to run the Flake8 check every time you write a Python file, to enable this, add the following line to your `.vimrc` file (thanks [Godefroid](https://github.com/gotcha)!): autocmd BufWritePost *.py call flake8#Flake8() This plugin goes well together with the following plugin: - [PyUnit](https://github.com/nvie/vim-pyunit) (unit test helper under `<F8>` and `<F9>`) Max line lengths ---------------- One particular customization a lot of people like to make is relaxing the maximum line length default. This is a config setting that should be set in flake8 itself. (vim-flake8 "just" invokes it and deals with showing the output in Vim's quickfix window.) To do so, put the following into a `.flake8` file at the root of your project: [flake8] max-line-length = 120 History ------- 1.6: Deprecated configuring flake8 options through Vim settings. Instead, advise users to use a `.flake8` config file in the root of your project. - Decprecated options: - `g:flake8_builtins` - `g:flake8_ignore` - `g:flake8_max_line_length` - `g:flake8_max_complexity` - New options: - `g:flake8_quickfix_height` 1.5: Added markers and the option to don't show the quickfix window, also split functions into a autoload file. Added: - Options: - `g:flake8_show_quickfix` - `g:flake8_show_in_gutter` - `g:flake8_show_in_file` - `g:flake8_max_markers` - `flake8_error_marker` - `flake8_warning_marker` - `flake8_pyflake_marker` - `flake8_complexity_marker` - `flake8_naming_marker` - Functions: - `flake8#Flake8UnplaceMarkers()` - `flake8#Flake8()` - Highlighting: - `Flake8_Error` - `Flake8_Warning` - `Flake8_Complexity` - `Flake8_Naming` - `Flake8_PyFlake` 1.4: Suppress output to stdout. 1.3: Added the following options: - `g:flake8_builtins="_,apply"` - `g:flake8_max_complexity=10` 1.2: Added the following options: - `g:flake8_cmd="/opt/strangebin/flake8000"` - `g:flake8_max_line_length=120` - `g:flake8_ignore="E501,W293"` 1.1: Added `g:flake8_ignore` option. 1.0: Initial version. License ------- Liberally licensed under BSD terms.