commit
75ff908059
24 changed files with 505 additions and 0 deletions
@ -0,0 +1,39 @@ |
|||
[submodule "bundle/colorschemes"] |
|||
path = bundle/colorschemes |
|||
url = https://github.com/flazz/vim-colorschemes.git |
|||
[submodule "bundle/python-mode"] |
|||
path = bundle/python-mode |
|||
url = https://github.com/python-mode/python-mode.git |
|||
[submodule "bundle/completor"] |
|||
path = bundle/completor |
|||
url = https://github.com/maralla/completor.vim.git |
|||
[submodule "bundle/syntastic"] |
|||
path = bundle/syntastic |
|||
url = https://github.com/vim-syntastic/syntastic.git |
|||
[submodule "bundle/nerdtree"] |
|||
path = bundle/nerdtree |
|||
url = https://github.com/preservim/nerdtree.git |
|||
[submodule "bundle/tagbar"] |
|||
path = bundle/tagbar |
|||
url = https://github.com/preservim/tagbar.git |
|||
[submodule "bundle/fugitive"] |
|||
path = bundle/fugitive |
|||
url = https://github.com/tpope/vim-fugitive.git |
|||
[submodule "bundle/airline"] |
|||
path = bundle/airline |
|||
url = https://github.com/vim-airline/vim-airline.git |
|||
[submodule "bundle/crystal"] |
|||
path = bundle/crystal |
|||
url = https://github.com/vim-crystal/vim-crystal.git |
|||
[submodule "bundle/virtualenv"] |
|||
path = bundle/virtualenv |
|||
url = https://github.com/jmcantrell/vim-virtualenv.git |
|||
[submodule "bundle/airline-themes"] |
|||
path = bundle/airline-themes |
|||
url = https://github.com/vim-airline/vim-airline-themes |
|||
[submodule "bundle/ruby"] |
|||
path = bundle/ruby |
|||
url = https://github.com/vim-ruby/vim-ruby.git |
|||
[submodule "bundle/sensible"] |
|||
path = bundle/sensible |
|||
url = https://github.com/tpope/vim-sensible.git |
@ -0,0 +1,264 @@ |
|||
" pathogen.vim - path option manipulation |
|||
" Maintainer: Tim Pope <http://tpo.pe/> |
|||
" Version: 2.4 |
|||
|
|||
" Install in ~/.vim/autoload (or ~\vimfiles\autoload). |
|||
" |
|||
" For management of individually installed plugins in ~/.vim/bundle (or |
|||
" ~\vimfiles\bundle), adding `execute pathogen#infect()` to the top of your |
|||
" .vimrc is the only other setup necessary. |
|||
" |
|||
" The API is documented inline below. |
|||
|
|||
if exists("g:loaded_pathogen") || &cp |
|||
finish |
|||
endif |
|||
let g:loaded_pathogen = 1 |
|||
|
|||
" Point of entry for basic default usage. Give a relative path to invoke |
|||
" pathogen#interpose() or an absolute path to invoke pathogen#surround(). |
|||
" Curly braces are expanded with pathogen#expand(): "bundle/{}" finds all |
|||
" subdirectories inside "bundle" inside all directories in the runtime path. |
|||
" If no arguments are given, defaults "bundle/{}", and also "pack/{}/start/{}" |
|||
" on versions of Vim without native package support. |
|||
function! pathogen#infect(...) abort |
|||
if a:0 |
|||
let paths = filter(reverse(copy(a:000)), 'type(v:val) == type("")') |
|||
else |
|||
let paths = ['bundle/{}', 'pack/{}/start/{}'] |
|||
endif |
|||
if has('packages') |
|||
call filter(paths, 'v:val !~# "^pack/[^/]*/start/[^/]*$"') |
|||
endif |
|||
let static = '^\%([$~\\/]\|\w:[\\/]\)[^{}*]*$' |
|||
for path in filter(copy(paths), 'v:val =~# static') |
|||
call pathogen#surround(path) |
|||
endfor |
|||
for path in filter(copy(paths), 'v:val !~# static') |
|||
if path =~# '^\%([$~\\/]\|\w:[\\/]\)' |
|||
call pathogen#surround(path) |
|||
else |
|||
call pathogen#interpose(path) |
|||
endif |
|||
endfor |
|||
call pathogen#cycle_filetype() |
|||
if pathogen#is_disabled($MYVIMRC) |
|||
return 'finish' |
|||
endif |
|||
return '' |
|||
endfunction |
|||
|
|||
" Split a path into a list. |
|||
function! pathogen#split(path) abort |
|||
if type(a:path) == type([]) | return a:path | endif |
|||
if empty(a:path) | return [] | endif |
|||
let split = split(a:path,'\\\@<!\%(\\\\\)*\zs,') |
|||
return map(split,'substitute(v:val,''\\\([\\,]\)'',''\1'',"g")') |
|||
endfunction |
|||
|
|||
" Convert a list to a path. |
|||
function! pathogen#join(...) abort |
|||
if type(a:1) == type(1) && a:1 |
|||
let i = 1 |
|||
let space = ' ' |
|||
else |
|||
let i = 0 |
|||
let space = '' |
|||
endif |
|||
let path = "" |
|||
while i < a:0 |
|||
if type(a:000[i]) == type([]) |
|||
let list = a:000[i] |
|||
let j = 0 |
|||
while j < len(list) |
|||
let escaped = substitute(list[j],'[,'.space.']\|\\[\,'.space.']\@=','\\&','g') |
|||
let path .= ',' . escaped |
|||
let j += 1 |
|||
endwhile |
|||
else |
|||
let path .= "," . a:000[i] |
|||
endif |
|||
let i += 1 |
|||
endwhile |
|||
return substitute(path,'^,','','') |
|||
endfunction |
|||
|
|||
" Convert a list to a path with escaped spaces for 'path', 'tag', etc. |
|||
function! pathogen#legacyjoin(...) abort |
|||
return call('pathogen#join',[1] + a:000) |
|||
endfunction |
|||
|
|||
" Turn filetype detection off and back on again if it was already enabled. |
|||
function! pathogen#cycle_filetype() abort |
|||
if exists('g:did_load_filetypes') |
|||
filetype off |
|||
filetype on |
|||
endif |
|||
endfunction |
|||
|
|||
" Check if a bundle is disabled. A bundle is considered disabled if its |
|||
" basename or full name is included in the list g:pathogen_blacklist or the |
|||
" comma delimited environment variable $VIMBLACKLIST. |
|||
function! pathogen#is_disabled(path) abort |
|||
if a:path =~# '\~$' |
|||
return 1 |
|||
endif |
|||
let sep = pathogen#slash() |
|||
let blacklist = get(g:, 'pathogen_blacklist', get(g:, 'pathogen_disabled', [])) + pathogen#split($VIMBLACKLIST) |
|||
if !empty(blacklist) |
|||
call map(blacklist, 'substitute(v:val, "[\\/]$", "", "")') |
|||
endif |
|||
return index(blacklist, fnamemodify(a:path, ':t')) != -1 || index(blacklist, a:path) != -1 |
|||
endfunction |
|||
|
|||
" Prepend the given directory to the runtime path and append its corresponding |
|||
" after directory. Curly braces are expanded with pathogen#expand(). |
|||
function! pathogen#surround(path) abort |
|||
let sep = pathogen#slash() |
|||
let rtp = pathogen#split(&rtp) |
|||
let path = fnamemodify(a:path, ':s?[\\/]\=$??') |
|||
let before = filter(pathogen#expand(path), '!pathogen#is_disabled(v:val)') |
|||
let after = filter(reverse(pathogen#expand(path, sep.'after')), '!pathogen#is_disabled(v:val[0 : -7])') |
|||
call filter(rtp, 'index(before + after, v:val) == -1') |
|||
let &rtp = pathogen#join(before, rtp, after) |
|||
return &rtp |
|||
endfunction |
|||
|
|||
" For each directory in the runtime path, add a second entry with the given |
|||
" argument appended. Curly braces are expanded with pathogen#expand(). |
|||
function! pathogen#interpose(name) abort |
|||
let sep = pathogen#slash() |
|||
let name = a:name |
|||
if has_key(s:done_bundles, name) |
|||
return "" |
|||
endif |
|||
let s:done_bundles[name] = 1 |
|||
let list = [] |
|||
for dir in pathogen#split(&rtp) |
|||
if dir =~# '\<after$' |
|||
let list += reverse(filter(pathogen#expand(dir[0 : -6].name, sep.'after'), '!pathogen#is_disabled(v:val[0 : -7])')) + [dir] |
|||
else |
|||
let list += [dir] + filter(pathogen#expand(dir.sep.name), '!pathogen#is_disabled(v:val)') |
|||
endif |
|||
endfor |
|||
let &rtp = pathogen#join(pathogen#uniq(list)) |
|||
return 1 |
|||
endfunction |
|||
|
|||
let s:done_bundles = {} |
|||
|
|||
" Invoke :helptags on all non-$VIM doc directories in runtimepath. |
|||
function! pathogen#helptags() abort |
|||
let sep = pathogen#slash() |
|||
for glob in pathogen#split(&rtp) |
|||
for dir in map(split(glob(glob), "\n"), 'v:val.sep."/doc/".sep') |
|||
if (dir)[0 : strlen($VIMRUNTIME)] !=# $VIMRUNTIME.sep && filewritable(dir) == 2 && !empty(split(glob(dir.'*.txt'))) && (!filereadable(dir.'tags') || filewritable(dir.'tags')) |
|||
silent! execute 'helptags' pathogen#fnameescape(dir) |
|||
endif |
|||
endfor |
|||
endfor |
|||
endfunction |
|||
|
|||
command! -bar Helptags :call pathogen#helptags() |
|||
|
|||
" Execute the given command. This is basically a backdoor for --remote-expr. |
|||
function! pathogen#execute(...) abort |
|||
for command in a:000 |
|||
execute command |
|||
endfor |
|||
return '' |
|||
endfunction |
|||
|
|||
" Section: Unofficial |
|||
|
|||
function! pathogen#is_absolute(path) abort |
|||
return a:path =~# (has('win32') ? '^\%([\\/]\|\w:\)[\\/]\|^[~$]' : '^[/~$]') |
|||
endfunction |
|||
|
|||
" Given a string, returns all possible permutations of comma delimited braced |
|||
" alternatives of that string. pathogen#expand('/{a,b}/{c,d}') yields |
|||
" ['/a/c', '/a/d', '/b/c', '/b/d']. Empty braces are treated as a wildcard |
|||
" and globbed. Actual globs are preserved. |
|||
function! pathogen#expand(pattern, ...) abort |
|||
let after = a:0 ? a:1 : '' |
|||
let pattern = substitute(a:pattern, '^[~$][^\/]*', '\=expand(submatch(0))', '') |
|||
if pattern =~# '{[^{}]\+}' |
|||
let [pre, pat, post] = split(substitute(pattern, '\(.\{-\}\){\([^{}]\+\)}\(.*\)', "\\1\001\\2\001\\3", ''), "\001", 1) |
|||
let found = map(split(pat, ',', 1), 'pre.v:val.post') |
|||
let results = [] |
|||
for pattern in found |
|||
call extend(results, pathogen#expand(pattern)) |
|||
endfor |
|||
elseif pattern =~# '{}' |
|||
let pat = matchstr(pattern, '^.*{}[^*]*\%($\|[\\/]\)') |
|||
let post = pattern[strlen(pat) : -1] |
|||
let results = map(split(glob(substitute(pat, '{}', '*', 'g')), "\n"), 'v:val.post') |
|||
else |
|||
let results = [pattern] |
|||
endif |
|||
let vf = pathogen#slash() . 'vimfiles' |
|||
call map(results, 'v:val =~# "\\*" ? v:val.after : isdirectory(v:val.vf.after) ? v:val.vf.after : isdirectory(v:val.after) ? v:val.after : ""') |
|||
return filter(results, '!empty(v:val)') |
|||
endfunction |
|||
|
|||
" \ on Windows unless shellslash is set, / everywhere else. |
|||
function! pathogen#slash() abort |
|||
return !exists("+shellslash") || &shellslash ? '/' : '\' |
|||
endfunction |
|||
|
|||
function! pathogen#separator() abort |
|||
return pathogen#slash() |
|||
endfunction |
|||
|
|||
" Convenience wrapper around glob() which returns a list. |
|||
function! pathogen#glob(pattern) abort |
|||
let files = split(glob(a:pattern),"\n") |
|||
return map(files,'substitute(v:val,"[".pathogen#slash()."/]$","","")') |
|||
endfunction |
|||
|
|||
" Like pathogen#glob(), only limit the results to directories. |
|||
function! pathogen#glob_directories(pattern) abort |
|||
return filter(pathogen#glob(a:pattern),'isdirectory(v:val)') |
|||
endfunction |
|||
|
|||
" Remove duplicates from a list. |
|||
function! pathogen#uniq(list) abort |
|||
let i = 0 |
|||
let seen = {} |
|||
while i < len(a:list) |
|||
if (a:list[i] ==# '' && exists('empty')) || has_key(seen,a:list[i]) |
|||
call remove(a:list,i) |
|||
elseif a:list[i] ==# '' |
|||
let i += 1 |
|||
let empty = 1 |
|||
else |
|||
let seen[a:list[i]] = 1 |
|||
let i += 1 |
|||
endif |
|||
endwhile |
|||
return a:list |
|||
endfunction |
|||
|
|||
" Backport of fnameescape(). |
|||
function! pathogen#fnameescape(string) abort |
|||
if exists('*fnameescape') |
|||
return fnameescape(a:string) |
|||
elseif a:string ==# '-' |
|||
return '\-' |
|||
else |
|||
return substitute(escape(a:string," \t\n*?[{`$\\%#'\"|!<"),'^[+>]','\\&','') |
|||
endif |
|||
endfunction |
|||
|
|||
" Like findfile(), but hardcoded to use the runtimepath. |
|||
function! pathogen#runtime_findfile(file,count) abort |
|||
let rtp = pathogen#join(1,pathogen#split(&rtp)) |
|||
let file = findfile(a:file,rtp,a:count) |
|||
if file ==# '' |
|||
return '' |
|||
else |
|||
return fnamemodify(file,':p') |
|||
endif |
|||
endfunction |
|||
|
|||
" vim:set et sw=2 foldmethod=expr foldexpr=getline(v\:lnum)=~'^\"\ Section\:'?'>1'\:getline(v\:lnum)=~#'^fu'?'a1'\:getline(v\:lnum)=~#'^endf'?'s1'\:'=': |
@ -0,0 +1,80 @@ |
|||
execute pathogen#infect() |
|||
execute pathogen#helptags() |
|||
|
|||
syntax enable |
|||
filetype plugin indent on |
|||
|
|||
set ruler |
|||
set magic |
|||
set mouse-=a |
|||
set showcmd |
|||
set showmatch |
|||
set smartcase |
|||
set incsearch |
|||
set hlsearch |
|||
set autoread |
|||
set wildmenu |
|||
set wildignore=*.o,*~,*.pyc |
|||
set backspace=eol,start,indent |
|||
set laststatus=2 |
|||
set cmdheight=1 |
|||
set lazyredraw |
|||
set encoding=utf8 |
|||
set ffs=unix,dos,mac |
|||
set pastetoggle=<F11> |
|||
set background=dark |
|||
|
|||
set noerrorbells |
|||
set novisualbell |
|||
set tm=500 |
|||
set t_vb= |
|||
set t_Co=256 |
|||
|
|||
set nobackup |
|||
set nowb |
|||
set noswapfile |
|||
|
|||
set expandtab |
|||
set smarttab |
|||
set shiftwidth=4 |
|||
set tabstop=4 |
|||
|
|||
set ai "Auto indent |
|||
set si "Smart indent |
|||
set wrap "Wrap lines |
|||
|
|||
" 快捷键映射 |
|||
let mapleader=',' |
|||
nmap <leader>w :w!<cr> |
|||
|
|||
map <silent> <leader><cr> :noh<cr> |
|||
|
|||
" :W sudo saves the file |
|||
command! W execute 'w !sudo tee % > /dev/null' <bar> edit! |
|||
|
|||
" 记下最后的编辑位置 |
|||
autocmd BufReadPost * if line("'\"") > 1 && line("'\"") <= line("$") | exe "normal! g'\"" | endif |
|||
|
|||
" Useful mappings for managing tabs |
|||
map <leader>tn :tabnew<cr> |
|||
map <leader>to :tabonly<cr> |
|||
map <leader>tc :tabclose<cr> |
|||
map <leader>tm :tabmove |
|||
map <leader>t<leader> :tabnext |
|||
|
|||
" Switch CWD to the directory of the open buffer |
|||
map <leader>cd :cd %:p:h<cr>:pwd<cr> |
|||
|
|||
" Delete trailing white space on save, useful for some filetypes ;) |
|||
fun! CleanExtraSpaces() |
|||
let save_cursor = getpos(".") |
|||
let old_query = getreg('/') |
|||
silent! %s/\s\+$//e |
|||
call setpos('.', save_cursor) |
|||
call setreg('/', old_query) |
|||
endfun |
|||
|
|||
if has("autocmd") |
|||
autocmd BufWritePre *.txt,*.js,*.py,*.wiki,*.sh,*.coffee :call CleanExtraSpaces() |
|||
endif |
|||
|
@ -0,0 +1,4 @@ |
|||
colorscheme molokai |
|||
|
|||
iab xdate <C-r>=strftime("%d/%m/%y %H:%M:%S")<cr> |
|||
|
@ -0,0 +1,4 @@ |
|||
autocmd BufNewFile,BufRead *.go set st=4 ts=4 |
|||
|
|||
autocmd FileType ruby compiler ruby |
|||
|
@ -0,0 +1,58 @@ |
|||
|
|||
" Bash like keys for the command line |
|||
cnoremap <C-A> <Home> |
|||
cnoremap <C-E> <End> |
|||
cnoremap <C-K> <C-U> |
|||
|
|||
cnoremap <C-P> <Up> |
|||
cnoremap <C-N> <Down> |
|||
|
|||
""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" |
|||
" => Parenthesis/bracket |
|||
"""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""""" |
|||
vnoremap $1 <esc>`>a)<esc>`<i(<esc> |
|||
vnoremap $2 <esc>`>a]<esc>`<i[<esc> |
|||
vnoremap $3 <esc>`>a}<esc>`<i{<esc> |
|||
vnoremap $$ <esc>`>a"<esc>`<i"<esc> |
|||
vnoremap $q <esc>`>a'<esc>`<i'<esc> |
|||
vnoremap $e <esc>`>a`<esc>`<i`<esc> |
|||
|
|||
" Map auto complete of (, ", ', [ |
|||
inoremap $1 ()<esc>i |
|||
inoremap $2 []<esc>i |
|||
inoremap $3 {}<esc>i |
|||
inoremap $4 {<esc>o}<esc>O |
|||
inoremap $q ''<esc>i |
|||
inoremap $e ""<esc>i |
|||
|
|||
map <leader>n :cn<cr> |
|||
map <leader>p :cp<cr> |
|||
|
|||
" ==> NERDTree |
|||
map <C-n> :NERDTreeToggle<CR> |
|||
map <F8> :TagbarToggle<CR> |
|||
|
|||
" ==> vim-ruby |
|||
if !exists( "*RubyEndToken" ) |
|||
|
|||
function RubyEndToken() |
|||
let current_line = getline( '.' ) |
|||
let braces_at_end = '{\s*\(|\(,\|\s\|\w\)*|\s*\)\?$' |
|||
let stuff_without_do = '^\s*\(class\|if\|unless\|begin\|case\|for\|module\|while\|until\|def\)' |
|||
let with_do = 'do\s*\(|\(,\|\s\|\w\)*|\s*\)\?$' |
|||
|
|||
if match(current_line, braces_at_end) >= 0 |
|||
return "\<CR>}\<C-O>O" |
|||
elseif match(current_line, stuff_without_do) >= 0 |
|||
return "\<CR>end\<C-O>O" |
|||
elseif match(current_line, with_do) >= 0 |
|||
return "\<CR>end\<C-O>O" |
|||
else |
|||
return "\<CR>" |
|||
endif |
|||
endfunction |
|||
|
|||
endif |
|||
|
|||
imap <buffer> <CR> <C-R>=RubyEndToken()<CR> |
|||
|
@ -0,0 +1,22 @@ |
|||
" ==> NERDTree |
|||
autocmd StdinReadPre * let s:std_in=1 |
|||
autocmd VimEnter * if argc() == 0 && !exists("s:std_in") | NERDTree | endif |
|||
autocmd VimEnter * if argc() == 1 && isdirectory(argv()[0]) && !exists("s:std_in") | exe 'NERDTree' argv()[0] | wincmd p | ene | exe 'cd '.argv()[0] | endif |
|||
autocmd BufEnter * if (winnr("$") == 1 && exists("b:NERDTree") && b:NERDTree.isTabTree()) | q | endif |
|||
|
|||
" ==> Airline |
|||
let g:airline_theme = 'wombat' |
|||
let g:airline#extensions#tabline#enabled = 1 |
|||
|
|||
" ==> Syntastic |
|||
set statusline+=%#warningmsg# |
|||
set statusline+=%{SyntasticStatuslineFlag()} |
|||
set statusline+=%* |
|||
|
|||
let g:syntastic_always_populate_loc_list = 1 |
|||
let g:syntastic_auto_loc_list = 1 |
|||
let g:syntastic_check_on_open = 1 |
|||
let g:syntastic_check_on_wq = 0 |
|||
|
|||
let g:syntastic_python_checkers = ['autopep8'] |
|||
|
@ -0,0 +1,10 @@ |
|||
#!/bin/bash |
|||
|
|||
bundle="$1" |
|||
|
|||
git submodule deinit -f "$bundle" |
|||
|
|||
git rm -rf "$bundle" |
|||
|
|||
git status |
|||
|
@ -0,0 +1,5 @@ |
|||
#!/bin/bash |
|||
|
|||
git submodule update --recursive --init --force |
|||
git submodule sync --recursive |
|||
|
@ -0,0 +1,6 @@ |
|||
source ~/.vim/configs/basic.vim |
|||
source ~/.vim/configs/filetypes.vim |
|||
source ~/.vim/configs/plugins.vim |
|||
source ~/.vim/configs/mapkeys.vim |
|||
source ~/.vim/configs/extended.vim |
|||
|
Loading…
Reference in new issue