diff options
author | William Carroll <wpcarro@gmail.com> | 2016-12-16T16·00-0500 |
---|---|---|
committer | William Carroll <wpcarro@gmail.com> | 2016-12-16T16·00-0500 |
commit | 17f7e0c453b18f794f7a9a1c76fd6d55dae64deb (patch) | |
tree | 15e8c82fe6e6edc2448eef2667270cd35d580c99 | |
parent | 4954544a5b38059ce772d3aa61cd148b3907732b (diff) |
Updates aliases and vim keybindings
-rw-r--r-- | aliases.sh | 2 | ||||
-rw-r--r-- | configs/.ctags | 15 | ||||
-rw-r--r-- | configs/.vimrc | 79 |
3 files changed, 70 insertions, 26 deletions
diff --git a/aliases.sh b/aliases.sh index 1910156b5af9..36149a41a9ae 100644 --- a/aliases.sh +++ b/aliases.sh @@ -8,7 +8,7 @@ alias grep="egrep" alias c="clear" -alias vi="vim" +alias vim="nvim" alias find="find -E" diff --git a/configs/.ctags b/configs/.ctags index 7899e7a21960..c018567f2041 100644 --- a/configs/.ctags +++ b/configs/.ctags @@ -7,6 +7,21 @@ --exclude=tmp +--langdef=Elixir +--langmap=Elixir:.ex.exs +--regex-Elixir=/^[ \t]*def(p?)[ \t]+([a-z_][a-zA-Z0-9_?!]*)/\2/f,functions,functions (def ...)/ +--regex-Elixir=/^[ \t]*defcallback[ \t]+([a-z_][a-zA-Z0-9_?!]*)/\1/c,callbacks,callbacks (defcallback ...)/ +--regex-Elixir=/^[ \t]*defdelegate[ \t]+([a-z_][a-zA-Z0-9_?!]*)/\1/d,delegates,delegates (defdelegate ...)/ +--regex-Elixir=/^[ \t]*defexception[ \t]+([A-Z][a-zA-Z0-9_]*\.)*([A-Z][a-zA-Z0-9_?!]*)/\2/e,exceptions,exceptions (defexception ...)/ +--regex-Elixir=/^[ \t]*defimpl[ \t]+([A-Z][a-zA-Z0-9_]*\.)*([A-Z][a-zA-Z0-9_?!]*)/\2/i,implementations,implementations (defimpl ...)/ +--regex-Elixir=/^[ \t]*defmacro(p?)[ \t]+([a-z_][a-zA-Z0-9_?!]*)\(/\2/a,macros,macros (defmacro ...)/ +--regex-Elixir=/^[ \t]*defmacro(p?)[ \t]+([a-zA-Z0-9_?!]+)?[ \t]+([^ \tA-Za-z0-9_]+)[ \t]*[a-zA-Z0-9_!?!]/\3/o,operators,operators (e.g. "defmacro a <<< b")/ +--regex-Elixir=/^[ \t]*defmodule[ \t]+([A-Z][a-zA-Z0-9_]*\.)*([A-Z][a-zA-Z0-9_?!]*)/\2/m,modules,modules (defmodule ...)/ +--regex-Elixir=/^[ \t]*defprotocol[ \t]+([A-Z][a-zA-Z0-9_]*\.)*([A-Z][a-zA-Z0-9_?!]*)/\2/p,protocols,protocols (defprotocol...)/ +--regex-Elixir=/^[ \t]*Record\.defrecord[ \t]+:([a-zA-Z0-9_]+)/\1/r,records,records (defrecord...)/ +--regex-Elixir=/^[ \t]*test[ \t]+\"([a-z_][a-zA-Z0-9_?! ]*)\"*/\1/t,tests,tests (test ...)/ + + --regex-ruby=/.*alias(_method)?[[:space:]]+:([[:alnum:]_=!?]+),?[[:space:]]+:([[:alnum:]_=!]+)/\2/f,function/ --regex-ruby=/(^|[:;])[ \t]*([A-Z][[:alnum:]_]+) *=/\2/c,class,constant/ --regex-ruby=/(^|;)[ \t]*(has_many|belongs_to|has_one|has_and_belongs_to_many)\(? *:([[:alnum:]_]+)/\3/f,function,association/ diff --git a/configs/.vimrc b/configs/.vimrc index 55b03752c54a..a40b3d62983c 100644 --- a/configs/.vimrc +++ b/configs/.vimrc @@ -21,9 +21,17 @@ Plugin 'Raimondi/delimitMate' " Displays git-tracked C*UD ops within gutter. Plugin 'airblade/vim-gitgutter' + +" Fuzzy-finder Plugin 'kien/ctrlp.vim' + +" Grep file contents Plugin 'mileszs/ack.vim' + +" JS support Plugin 'pangloss/vim-javascript' + +" Visual dir-tree navigation Plugin 'scrooloose/nerdtree' " Syntax Highlighting Support @@ -65,6 +73,9 @@ Plugin 'christoomey/vim-tmux-navigator' " Async `:make` for code linting etc. Plugin 'neomake/neomake' +" Color pack +Plugin 'flazz/vim-colorschemes' + call vundle#end() " required filetype plugin indent on " required @@ -94,6 +105,9 @@ let g:neomake_elixir_credo_maker = { " Enables the list of buffers. let g:airline#extensions#tabline#enabled = 1 +" Buffer numbers alongside files +let g:airline#extensions#tabline#buffer_nr_show = 1 + " Shows the filename only. let g:airline#extensions#tabline#fnamemod = ':t' @@ -101,7 +115,20 @@ let g:airline#extensions#tabline#fnamemod = ':t' let g:airline_powerline_fonts = 1 " Change Airline theme -let g:airline_theme = 'base16_google' +let g:airline_theme = 'hybrid' + + +" Jump to buffers. +nmap <F1> :1b<CR> +nmap <F2> :2b<CR> +nmap <F3> :3b<CR> +nmap <F4> :4b<CR> +nmap <F5> :5b<CR> +nmap <F6> :6b<CR> +nmap <F7> :7b<CR> +nmap <F8> :8b<CR> +nmap <F9> :9b<CR> + " It's the twenty-first century...no swaps. @@ -171,8 +198,7 @@ set mouse=a set hlsearch " Search for gibberish to clear the most recent search -" nnoremap <leader>/ :set hlsearch!<CR> -noremap <leader>/ /__wc_gibberish__<CR> +noremap <leader>/ :silent! /__wc_gibberish__/<CR>:echo "Search cleared."<CR> " Use custom-made snippets. @@ -207,10 +233,10 @@ inoremap <C-e> <Esc>A " Manage Vertical and Horizontal splits -nnoremap vs <Esc>:vs<CR> -nnoremap vv <Esc>:vs<CR> -nnoremap sp <Esc>:sp<CR> -nnoremap ss <Esc>:sp<CR> +nnoremap sl <Esc>:vs<CR><C-w>l +nnoremap sh <Esc>:vs<CR> +nnoremap sj <Esc>:sp<CR><C-w>j +nnoremap sk <Esc>:sp<CR> " Move around splits with <leader> @@ -228,7 +254,7 @@ nnoremap <leader>q :bdelete<CR> " CtrlP config " Set default CtrlP command. -let g:ctrlp_cmd = 'CtrlP' +let g:ctrlp_cmd = 'CtrlPBuffer' " let g:ctrlp_cmd = 'CtrlPMRU' " Set runtime path @@ -268,8 +294,8 @@ nnoremap Y y$ " nnoremap <C-k> k<C-y> -" reload file after git changes -nnoremap <C-r> :e<CR> +" Shorter binding for window rotations +nnoremap <C-r> <C-w><C-r> " Basic settings @@ -281,7 +307,7 @@ set shiftwidth=2 set background=dark syntax enable -colorscheme solarized +colorscheme hybrid set history=1000 set undolevels=1000 @@ -293,6 +319,10 @@ set t_Co=255 highlight Comment cterm=italic +" remap redo key that is eclipsed by `rotate` currently +nnoremap U :redo<CR> + + " Repeat last colon-command nnoremap ;; @:<CR> vnoremap ;; @:<CR> @@ -322,7 +352,7 @@ nnoremap <C-c> V"+y vnoremap <C-c> "+y inoremap <C-v> <Esc>"+pa -nnoremap <C-v> o<Esc>"+p +" nnoremap <C-v> o<Esc>"+p vnoremap <C-v> "+p @@ -396,7 +426,7 @@ vnoremap // y/<C-r>"<CR>N " trim trailing whitespace on save -autocmd BufWritePre *.{js,py,tpl,less,html,ex} :%s/\s\+$//e +autocmd BufWritePre *.{js,py,tpl,less,html,ex,exs,txt} :%s/\s\+$//e " set default font and size @@ -420,24 +450,25 @@ nnoremap <leader>t :call ExTestToggle()<CR> " Jumps from an Elixir module file to an Elixir test file. fun! ExTestToggle() - if expand('%:e') == "ex" - let l:test_file_name = expand('%:t:r') . "_test.exs" - let l:test_file_dir = substitute(expand('%:p:h'), "/lib/core/", "/lib/test/", "") - let l:full_test_path = join([test_file_dir, test_file_name], "/") + + let test_file_name = expand('%:t:r') . "_test.exs" + let test_file_dir = substitute(expand('%:p:h'), "/lib/", "/test/", "") + let full_test_path = join([test_file_dir, test_file_name], "/") e `=full_test_path` elseif match(expand('%:t'), "_test.exs") != -1 - let l:current_file_name = expand('%:t:r') - let l:offset_amt = strlen(current_file_name) - strlen("_test") - let l:module_file_name = strpart(current_file_name, 0, offset_amt) . ".ex" - let l:module_file_dir = substitute(expand('%:p:h'), "/test/", "/lib/core/", "") - let l:full_module_path = join([module_file_dir, module_file_name], "/") + + let test_file_name = expand('%:t:r') + let offset_amt = strlen(test_file_name) - strlen("_test") + let module_file_name = strpart(test_file_name, 0, offset_amt) . ".ex" + let module_file_dir = substitute(expand('%:p:h'), "/test/", "/lib/", "") + let full_module_path = join([module_file_dir, module_file_name], "/") e `=full_module_path` - endif + endif endfun @@ -449,5 +480,3 @@ fun! CreateNonExistingDirsAndFile() w endfun - - |