Adds elixir support; extends tmux config; adds vim viewport key-bindings
This commit is contained in:
parent
7d5ad2b2b9
commit
dded5d6497
4 changed files with 55 additions and 11 deletions
|
@ -23,3 +23,6 @@ alias ccat="pygmentize -g"
|
|||
# pushd and popd commands
|
||||
alias wdirs='dirs | tr " " "\n" | sort -r'
|
||||
|
||||
# Pretty-print git history
|
||||
alias glp="git log --graph --pretty=format:'%Cred%h%Creset -%Cblue %an %Creset - %C(yellow)%d%Creset %s %Cgreen(%cr)%Creset' --abbrev-commit --date=relative"
|
||||
|
||||
|
|
|
@ -1,40 +1,57 @@
|
|||
# change tmux leader
|
||||
unbind C-b
|
||||
set -g prefix C-a
|
||||
bind C-a send-prefix
|
||||
|
||||
|
||||
# COLORS!
|
||||
set -g default-terminal "screen-256color"
|
||||
set -g default-terminal "tmux-256color-italic"
|
||||
|
||||
|
||||
#copy-paste fixes: http://evertpot.com/osx-tmux-vim-copy-paste-clipboard/
|
||||
# Copy-paste integration
|
||||
set-option -g default-command "reattach-to-user-namespace -l zsh"
|
||||
|
||||
|
||||
# Use vim keybindings in copy mode
|
||||
setw -g mode-keys vi
|
||||
|
||||
|
||||
# Setup 'v' to begin selection as in Vim
|
||||
bind-key -t vi-copy v begin-selection
|
||||
bind-key -t vi-copy y copy-pipe "reattach-to-user-namespace pbcopy"
|
||||
|
||||
|
||||
# Update default binding of `Enter` to also use copy-pipe
|
||||
unbind -t vi-copy Enter
|
||||
bind-key -t vi-copy Enter copy-pipe "reattach-to-user-namespace pbcopy"
|
||||
|
||||
|
||||
# Bind ']' to use pbpaste
|
||||
bind ] run "reattach-to-user-namespace pbpaste | tmux load-buffer - && tmux paste-buffer"
|
||||
|
||||
|
||||
# fix for slow ESC issues
|
||||
set -s escape-time 0
|
||||
|
||||
|
||||
# start window indicies at 1
|
||||
set -g base-index 1
|
||||
|
||||
|
||||
# window naming nonsense
|
||||
set-window-option -g automatic-rename on
|
||||
set-window-option -g allow-rename off
|
||||
|
||||
|
||||
# new windows carry over current working directory
|
||||
bind c new-window -c '#{pane_current_path}'
|
||||
|
||||
|
||||
# mouse mode
|
||||
set-option -g mouse on
|
||||
|
||||
|
||||
# Make tmux work like vi
|
||||
set-window-option -g mode-keys vi
|
||||
bind h select-pane -L
|
||||
|
@ -42,20 +59,24 @@ bind j select-pane -D
|
|||
bind k select-pane -U
|
||||
bind l select-pane -R
|
||||
|
||||
|
||||
# Easier window swaps
|
||||
bind -n C-left swap-window -t -1
|
||||
bind -n C-right swap-window -t +1
|
||||
|
||||
|
||||
# Easier window moves
|
||||
bind -n m-left previous-window
|
||||
bind -n m-right next-window
|
||||
|
||||
|
||||
# window resizing
|
||||
bind -n S-Up resize-pane -U 5
|
||||
bind -n S-Down resize-pane -D 5
|
||||
bind -n S-Left resize-pane -L 10
|
||||
bind -n S-Right resize-pane -R 10
|
||||
|
||||
|
||||
# Option + number to jump to window
|
||||
bind -n m-0 select-window -t 0
|
||||
bind -n m-1 select-window -t 1
|
||||
|
@ -68,6 +89,7 @@ bind -n m-7 select-window -t 7
|
|||
bind -n m-8 select-window -t 8
|
||||
bind -n m-9 select-window -t 9
|
||||
|
||||
|
||||
# Option + l to toggle between sessions
|
||||
# bind -n m-l switch-client -l
|
||||
bind -n m-s choose-session
|
||||
|
|
|
@ -19,9 +19,6 @@ Plugin 'tpope/vim-fugitive'
|
|||
|
||||
Plugin 'Raimondi/delimitMate'
|
||||
|
||||
" Autocompletion
|
||||
Plugin 'Valloric/YouCompleteMe'
|
||||
|
||||
" Displays git-tracked C*UD ops within gutter.
|
||||
Plugin 'airblade/vim-gitgutter'
|
||||
Plugin 'kien/ctrlp.vim'
|
||||
|
@ -36,7 +33,7 @@ Plugin 'lambdatoast/elm.vim'
|
|||
" Elixir Plugins
|
||||
Plugin 'elixir-lang/vim-elixir'
|
||||
Plugin 'slashmili/alchemist.vim'
|
||||
Plugin 'powerman/vim-plugin-ANsiEsc'
|
||||
Plugin 'powerman/vim-plugin-AnsiEsc'
|
||||
|
||||
" TypeScript Plugins
|
||||
Plugin 'rschmukler/typescript-vim'
|
||||
|
@ -194,7 +191,7 @@ nnoremap <C-l> :1bnext<CR>
|
|||
nnoremap <C-h> :1bprevious<CR>
|
||||
|
||||
" Buffer creation
|
||||
nnoremap <C-t> :enew<CR>
|
||||
" nnoremap <C-t> :enew<CR>
|
||||
|
||||
" Buffer deletion
|
||||
nnoremap <leader>bq :bp <BAR> bd #<CR>
|
||||
|
@ -380,13 +377,18 @@ nnoremap <leader>v8 :resize 40<CR>
|
|||
" Show hidden files by default. (Toggle with capital 'i')
|
||||
let NERDTreeShowHidden=1
|
||||
|
||||
" View Directory tree with ctrl + \
|
||||
nnoremap <C-\> :NERDTreeToggle<CR>
|
||||
" View Directory tree with ctrl + n
|
||||
nnoremap <C-t> :NERDTreeToggle<CR>
|
||||
|
||||
" View open buffer location in tree.
|
||||
nnoremap <C-o> :NERDTreeFind<CR>
|
||||
|
||||
|
||||
" Jump to the top / bottom of the Viewport
|
||||
nnoremap K H
|
||||
nnoremap J L
|
||||
|
||||
|
||||
" BOL and EOL
|
||||
nnoremap H ^
|
||||
vnoremap H ^
|
||||
|
@ -399,7 +401,7 @@ vnoremap // y/<C-r>"<CR>
|
|||
|
||||
|
||||
" trim trailing whitespace on save
|
||||
autocmd BufWritePre *.{js,py,tpl,less,html} :%s/\s\+$//e
|
||||
autocmd BufWritePre *.{js,py,tpl,less,html,ex} :%s/\s\+$//e
|
||||
|
||||
|
||||
" set default font and size
|
||||
|
@ -417,6 +419,11 @@ nnoremap <leader>p :CtrlP<CR>
|
|||
" Fuzzy-finds files within cwd.
|
||||
" nnoremap <leader>pf :CtrlP<CR>
|
||||
|
||||
|
||||
" Use .gitignore file to populate Ctrl-P
|
||||
let g:ctrlp_user_command = ['.git', 'cd %s && git ls-files . -co --exclude-standard', 'find %s -type f']
|
||||
|
||||
|
||||
" Ignores dirs and files
|
||||
let g:ctrlp_custom_ignore = {
|
||||
\ 'dir': 'node_modules',
|
||||
|
|
|
@ -46,7 +46,19 @@ function trim {
|
|||
}
|
||||
|
||||
|
||||
function wgreviewers {
|
||||
echo "BJ Warshaw\nDaniel Wasilewski\nSean Sullivan\nCharles Morrissey\nRyan Balch\nZach Goldstein\nWilliam Anderson"
|
||||
function tt() {
|
||||
sessionName="${1}"
|
||||
if ! tmux has-session -t "${sessionName}" 2> /dev/null; then
|
||||
oldTMUX="${TMUX}"
|
||||
unset TMUX
|
||||
tmux new -d -s "${sessionName}"
|
||||
export TMUX="${oldTMUX}"
|
||||
unset oldTMUX
|
||||
fi
|
||||
if [[ -n "${TMUX}" ]]; then
|
||||
tmux switch-client -t "${sessionName}"
|
||||
else
|
||||
tmux attach -t "${sessionName}"
|
||||
fi
|
||||
}
|
||||
|
||||
|
|
Loading…
Reference in a new issue