-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathdot_vimrc
107 lines (93 loc) · 3.3 KB
/
dot_vimrc
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
" vi:ft=vim
" Vundle setup
set nocompatible " be iMproved, required
filetype off " required
" set the runtime path to include Vundle and initialize
set rtp+=$HOME/.vim/bundle/Vundle.vim
call vundle#begin()
" alternatively, pass a path where Vundle should install plugins
"call vundle#begin('~/some/path/here')
" let Vundle manage Vundle, required
Plugin 'VundleVim/Vundle.vim'
" for folding (collapsing) code blocks
Plugin 'tmhedberg/SimpylFold'
" for Python auto-indents
Plugin 'vim-scripts/indentpython.vim'
" for autocompletions
Bundle 'Valloric/YouCompleteMe'
" for syntax highlighting
Plugin 'vim-syntastic/syntastic'
" color scheme
Plugin 'connorholyday/vim-snazzy'
" for file browsing
Plugin 'scrooloose/nerdtree'
" for Git integration
Plugin 'tpope/vim-fugitive'
" for fuzzy finding
Plugin 'junegunn/fzf'
" All of your Plugins must be added before the following line
call vundle#end() " required
filetype plugin indent on " required
" To ignore plugin indent changes, instead use:
"filetype plugin on
"
" Brief help
" :PluginList - lists configured plugins
" :PluginInstall - installs plugins; append `!` to update or just :PluginUpdate
" :PluginSearch foo - searches for foo; append `!` to refresh local cache
" :PluginClean - confirms removal of unused plugins; append `!` to auto-approve removal
"
" see :h vundle for more details or wiki for FAQ
" Put your non-Plugin stuff after this line
" General preferences
" Disable bell sounds
set belloff=all
" Show line numbers
set number
" Enable folding
set foldmethod=indent
set foldlevel=99
" Enable folding with the spacebar
nnoremap <space> za
" Configure desired tab behavior, max line width, auto indents, and file format, when editing python files
au BufNewFile,BufRead *.py
\ set tabstop=4 |
\ set softtabstop=4 |
\ set shiftwidth=4 |
\ set textwidth=119 |
\ set expandtab |
\ set autoindent |
\ set fileformat=unix
" Show error when unnecessary newlines are found
" au BufRead,BufNewFile *.py match BadWhitespace /\s\+$/
" Configure the same for frontend files
au BufNewFile,BufRead *.js,*.html,*.css
\ set tabstop=4 |
\ set softtabstop=4 |
\ set shiftwidth=4 |
\ set textwidth=119 |
\ set noexpandtab |
\ set autoindent |
\ set fileformat=unix
" Set encoding
set encoding=utf-8
" Close autocomplete windows when done
let g:ycm_autoclose_preview_window_after_completion=1
" Map jump-to-definition to shortcut
map <leader>g :YcmCompleter GoToDefinitionElseDeclaration<CR>
" Enable Python syntax highlighting
let python_highlight_all=1
syntax on
" Make snazzy color scheme background transparent
let g:SnazzyTransparent = 1
" Use snazzy color scheme
colorscheme snazzy
" Start NERDTree when Vim is started without file arguments
autocmd StdinReadPre * let s:std_in=1
autocmd VimEnter * if argc() == 0 && !exists('s:std_in') | NERDTree | endif
" Open the existing NERDTree on each new tab
autocmd BufWinEnter * if getcmdwintype() == '' | silent NERDTreeMirror | endif
" Close the tab if NERDTree is the only window remaining in it
autocmd BufEnter * if winnr('$') == 1 && exists('b:NERDTree') && b:NERDTree.isTabTree() | quit | endif
" Automatically save dotfiles changes when editing chezmoi-managed files
autocmd BufWritePost $HOME/.local/share/chezmoi/* ! chezmoi apply --source-path "%"