diff options
-rw-r--r-- | aliases.sh | 3 | ||||
-rw-r--r-- | configs/.tmux.conf | 24 | ||||
-rw-r--r-- | configs/.vimrc | 23 | ||||
-rw-r--r-- | functions/misc_functions.sh | 16 |
4 files changed, 55 insertions, 11 deletions
diff --git a/aliases.sh b/aliases.sh index c427af58e9be..1910156b5af9 100644 --- a/aliases.sh +++ b/aliases.sh @@ -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" + diff --git a/configs/.tmux.conf b/configs/.tmux.conf index 05c0d6515755..1a7918444b82 100644 --- a/configs/.tmux.conf +++ b/configs/.tmux.conf @@ -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 diff --git a/configs/.vimrc b/configs/.vimrc index 5b08f2c778a7..a6f78c83f120 100644 --- a/configs/.vimrc +++ b/configs/.vimrc @@ -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', diff --git a/functions/misc_functions.sh b/functions/misc_functions.sh index ed7f6293c08f..728c6e453b8a 100644 --- a/functions/misc_functions.sh +++ b/functions/misc_functions.sh @@ -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 } |