2011-12-18 05:27:01 +08:00
_ _ _
| | | | | |
| |___| |_____ __ | | ____
|_____ (____ |/ _ |/ ___)
_____ | / ___ ( (_| | |
(_______\_____|\____|_|
2011-11-18 05:45:33 +08:00
2011-12-18 06:11:05 +08:00
# Yet Another Dotfile Repo v0.8
2011-12-18 05:27:01 +08:00
# Alpha Release Please Report Bugs
2011-12-16 19:33:25 +08:00
2011-12-18 05:27:01 +08:00
git clone https://github.com/skwp/dotfiles ~/.dotfiles
~/.dotfiles/bin/yadr/yadr init-plugins
# Your dotfiles are safe! YADR will not
# overwrite anything. Please read on for
# install directions!
2011-11-18 06:40:21 +08:00
2011-12-07 13:57:45 +08:00
This is a collection of best of breed tools from across the web,
from scouring other people's dotfile repos, blogs, and projects.
2011-12-30 09:35:45 +08:00
What is YADR?
2011-12-08 12:54:03 +08:00
---
2011-12-18 06:40:58 +08:00
**YADR is an opinionated dotfile repo that will make your heart sing**
* OSX is the best OS. MacVim is the best editor. Zsh is the best shell. Pry is the best irb. Solarized is the best color scheme.
* Apple-style philosophy: make everything Just Work and Look Good. Don't worry about too many options.
2011-12-07 13:57:45 +08:00
* All common commands should be two and three character mnemonic aliases - less keystrokes, RSI reduction
2011-12-18 06:40:58 +08:00
* Avoid stressful hand motions, e.g. remap Esc to caps lock key, remap underscore to Alt-k in vim, make window management in vim easy.
2011-12-08 12:54:03 +08:00
* Easy to use plugin architecture, no config files to edit.
* Pick one tool and use it everywhere: vim-ize everything
2011-12-18 06:11:05 +08:00
* **NEW Beautiful, easy to read and small vimrc**
* **NEW No key overrides or custom hackery in vimrc, everything in well factored snippets in .vim/plugin/settings**
2011-12-08 12:54:03 +08:00
2011-12-18 06:40:58 +08:00
Why is this not a fork of Janus?
2011-12-08 12:54:03 +08:00
---
2011-12-18 06:40:58 +08:00
Janus is an amazing _first effort_ to deliver a ready-to-use vim setup and is a huge inspiration to us all.
**However as any first effort, it paves the way to improvements:**
2011-12-08 12:54:03 +08:00
2011-12-18 06:40:58 +08:00
* Much larger list of vim plugins, specifically geared to Ruby/Rails/Git development.
* Optimized support for MacVim only means less things will break because we don't worry about linux or gvim.
* Optimized support for Solarized color scheme only, everything guaranteed to Look Good. Your eyes will thank you.
* All plugins tested with Solarized and custom color maps provided where needed to ensure your eyes will not bleed.
* No configuration file to maintain. YADR uses tiny ruby scripts to wrap git submodule maintenance.
* Much cleaner vimrc that does not introduce any new key maps. (Janus: 160 lines vimrc, 260 lines gvimrc; YADR: 90 lines vimrc with great comments)
* All keymaps and customization in small, easy to maintain files under .vim/plugin/settings
* More than just vim plugins - great shell aliases, osx, and irb/pry tweaks to make you more productive.
2011-12-07 13:57:45 +08:00
2011-12-20 18:19:42 +08:00
Screenshot
---
![screenshot ](http://i.imgur.com/lEFlF.png )
2011-12-07 13:57:45 +08:00
Before you start
---
2011-12-18 06:40:58 +08:00
For the love of all that is holy, stop abusing your hands!
Remap caps-lock to escape: http://pqrs.org/macosx/keyremap4macbook/extra.html
2011-12-07 13:57:45 +08:00
2011-12-08 15:27:41 +08:00
Installation
---
2011-12-07 13:57:45 +08:00
2011-12-08 15:27:41 +08:00
This project uses git submodules for its plugins, but this is handled
for you by the **yadr** command. Please run:
git clone https://github.com/skwp/dotfiles ~/.dotfiles
~/.dotfiles/bin/yadr/yadr init-plugins
2011-11-19 00:19:31 +08:00
2012-01-03 04:27:36 +08:00
NOTE: by default, YADR will not touch any of your files. You have to manually
2011-12-08 15:27:41 +08:00
activate each of its components, if you choose, by following the sections below.
Eventually these will be automated.
2011-11-19 00:19:31 +08:00
2011-12-08 15:27:41 +08:00
If you pull new changes, be sure to run this to init all the submodules:
2011-11-19 00:19:31 +08:00
2011-12-08 15:27:41 +08:00
yadr init-plugins
After you install yadr shell aliases, you can use the *yip* alias to do the same.
2011-12-09 02:05:53 +08:00
Please note that init-plugins will automatically compile the CommandT plugin for you.
2011-11-19 00:19:31 +08:00
2011-11-23 09:02:36 +08:00
Setup for ZSH
---
2011-12-08 15:27:41 +08:00
After a lifetime of bash, I am now using ZSH as my default shell because of its awesome globbing
2012-01-03 04:27:36 +08:00
and autocomplete features (the spelling fixer autocomplete is worth the money alone).
2011-12-07 13:57:45 +08:00
2011-12-08 15:27:41 +08:00
Migrating from bash to zsh is essentially pain free. The zshrc provided here
restores the only feature that I felt was 'broken' which is the Ctrl-R reverse history search.
While I am not going to support bash out of the box here, YADR _should_ work with bash if
2011-12-18 06:11:05 +08:00
you just source the _aliases_ file. However, you soul will sing if you install zsh. I promise.
2011-12-19 05:08:35 +08:00
**Install zsh pain free, automatically:**
2011-11-23 09:02:36 +08:00
2011-12-08 15:27:41 +08:00
wget --no-check-certificate https://github.com/robbyrussell/oh-my-zsh/raw/master/tools/install.sh -O - | sh
2011-12-18 06:11:05 +08:00
2011-12-19 05:08:35 +08:00
Place this as the last line in your ~/.zshrc created by oh-my-zsh:
2011-11-23 09:02:36 +08:00
2011-12-07 18:48:00 +08:00
source ~/.dotfiles/zsh/zshrc
2011-11-23 09:02:36 +08:00
2011-12-19 05:08:35 +08:00
Or, to make things simpler you can just use the YADR-provided zsh/oh_my_zsh_zshrc
Please note that this relies on the skwp fork of oh-my-zsh which contains skwp.theme
ln -sf ~/.dotfiles/zsh/oh_my_zsh_zshrc ~/.zshrc
2012-01-03 04:27:36 +08:00
Lots of things I do every day are done with two or three character
2011-12-19 05:08:35 +08:00
mnemonic aliases. Please feel free to edit them:
2011-11-18 05:45:33 +08:00
ae # alias edit
ar # alias reload
2011-12-18 06:11:05 +08:00
**Customized zsh provided by ~/.dotfiles/zshrc:**
2011-12-07 13:57:45 +08:00
* Vim mode
* Bash style ctrl-R for reverse history finder
2011-12-08 15:27:41 +08:00
* Fuzzy matching - if you mistype a directory name, tab completion will fix it
2011-12-07 13:57:45 +08:00
2011-12-06 16:40:44 +08:00
Setup for Pry
---
2012-01-03 04:27:36 +08:00
Pry (http://pry.github.com/) offers a much better out of the box IRB experience
2011-12-06 16:40:44 +08:00
with colors, tab completion, and lots of other tricks. You should:
gem install pry
gem install awesome_print
ln -s ~/.dotfiles/irb/pryrc ~/.pryrc
ln -s ~/.dotfiles/irb/aprc ~/.aprc
2011-12-18 06:11:05 +08:00
**Use pry**
2011-12-07 13:57:45 +08:00
* as irb: 'pry'
* as rails console: script/console --irb=pry
2011-12-18 06:11:05 +08:00
**Pry customizations:**
2011-12-07 13:57:45 +08:00
* 'clear' command to clear screen
* 'sql' command to execute something (within a rails console)
* all objects displayed in readable format (colorized, sorted hash keys) - via awesome_print
* a few color modifications to make it more useable
* type 'help' to see all the commands
2011-12-06 16:40:44 +08:00
2011-11-18 06:50:58 +08:00
Setup for Vim
---
2011-11-18 05:45:33 +08:00
To use the vim files:
ln -s ~/.dotfiles/vimrc ~/.vimrc
ln -s ~/.dotfiles/vim ~/.vim
2011-12-19 05:08:35 +08:00
2011-11-18 05:45:33 +08:00
The .vimrc is well commented and broken up by settings. I encourage you
to take a look and learn some of my handy aliases, or comment them out
if you don't like them, or make your own.
2011-12-13 13:04:42 +08:00
Vim Keymaps (in vim/plugin/settings)
---
2011-11-18 06:40:21 +08:00
2012-01-03 04:27:36 +08:00
The files in vim/plugin/settings are customizations stored on a per-plugin
2011-12-13 13:04:42 +08:00
basis. The main keymap is available in skwp-keymap.vim, but some of the vim
files contain key mappings as well (TODO: probably will move them out to skwp-keymap.vim)
2011-12-18 06:11:05 +08:00
**Navigation**
2011-12-13 13:04:42 +08:00
* ,z - jump back and forth between last two buffers
2011-12-16 16:04:14 +08:00
* Ctrl-j and Ctrl-k to move up and down roughly by functions
2011-12-21 15:48:33 +08:00
* Ctrl-o - Old cursor position - this is a standard mapping but very useful, so included here
* Ctrl-i - opposite of Ctrl-O (again, this is standard)
**Marks**
2012-01-21 10:46:57 +08:00
* ,mm - set the next available mark (set a mark with mX where X is a letter, navigate to mark using 'X). Uppercase marks to mark files, lowercase marks to use within a file.
* ,ma - clear all marks
* ,mh - clear current mark
2012-01-21 10:01:06 +08:00
* ,Bt - toggle local anonymous bookmark at current location
* ,Bn ,Bp - next and previous anonymous bookmark
* ,Bc - clear anonymous bookmarks
2011-12-13 13:04:42 +08:00
2011-12-18 06:11:05 +08:00
**LustyJuggler**
2011-12-13 13:04:42 +08:00
2012-01-21 10:01:06 +08:00
* ,lj - show buffers (LustyJuggler buffer search), just type to fuzzy match a buffer name
2011-12-13 13:04:42 +08:00
2011-12-18 06:11:05 +08:00
**Rails**
2011-12-13 13:04:42 +08:00
2011-12-16 14:20:51 +08:00
* ,ru - Rails Unittest - synonym for :AV from rails.vim, opens up the corresponding test/spec to the file you're looking for, in a vertical split
2012-01-21 10:46:57 +08:00
* ,ss to run specs, ,ll to run a given spec on a line - using my vim-ruby-conque plugin (https://github.com/skwp/vim-ruby-conque)
2011-12-24 13:05:50 +08:00
* Cmd-Shift-R to use vim-rspec to run a spec file. Cmd-Shift-L to run from a line (individual it block)
2011-12-13 13:04:42 +08:00
2011-12-18 06:11:05 +08:00
**Surround.vim customizations**
2011-12-18 05:27:01 +08:00
* in plugin/settings/surround.vim (this folder contains all my customizations)
* the # key now surrounds with #{}, so - ysaw# surround around word #{foo}
* = surrounds with < %= erb tag %> and - for < % this %>, so yss= or yss- to wrap code
2011-12-18 06:11:05 +08:00
**Search/Code Navigation**
2011-12-11 18:05:29 +08:00
2011-12-16 16:04:14 +08:00
* ,f - instantly Find definition of class (must have exuberant ctags installed)
2012-01-21 11:17:35 +08:00
* K - GitGrep the current word under the cursor and show results in quickfix window
* ,K - GitGrep the current word up to next exclamation point (useful for ruby foo! methods)
2011-12-13 10:21:42 +08:00
* Cmd-* - highlight all occurrences of current word (similar to regular * except doesn't move)
* ,hl - toggle search highlight on and off
2011-12-11 18:05:29 +08:00
* ,gg - GitGrep command line with a quote pretyped (close the quote yourself)
* ,gcp - GitGrep Current Partial to find references to the current view partial
2011-12-13 13:04:42 +08:00
* // - clear the search
2012-01-21 10:43:49 +08:00
* ,q/ - quickfix window with last search (stolen from Steve Losh)
* ,qa/ - quickfix Ack last search (Steve Losh)
* ,qg/ - quickfix GitGrep last search
2011-12-13 13:04:42 +08:00
* ,T - Tag list (list of methods in a class)
2011-12-24 06:13:59 +08:00
**File Navigation**
2011-12-28 02:43:38 +08:00
2011-12-24 06:13:59 +08:00
* ,t - Command-T fuzzy file selector
2012-01-21 10:01:06 +08:00
* ,b - Command-T buffer selector
2011-12-24 06:13:59 +08:00
* ,jm jump (command-t) app/models
* ,jc app/controllers
* ,jv app/views
* ,jh app/helpers
* ,jl lib
* ,jp public
* ,js spec
* ,jf fast_spec
* ,jt test
* ,jd db
* ,jC config
* ,jV vendor
* ,jF factories
2011-12-18 06:11:05 +08:00
**RSI-reduction**
2012-01-03 04:27:36 +08:00
2011-12-21 15:48:33 +08:00
* Cmd-k and Cmd-d to type underscores and dashes (use Shift), since they are so common in code but so far away from home row
2011-12-16 14:20:51 +08:00
* ; instead of : - avoid Shift for common tasks, just hit semicolon to get to ex mode
2011-12-18 05:27:01 +08:00
* ,. to go to last edit location instead of '. because the apostrophe is hard on the pinky
2012-01-07 02:24:58 +08:00
* Cmd-' and Cmd-" to change content inside quotes
2011-12-13 13:04:42 +08:00
2011-12-18 06:11:05 +08:00
**Tab Navigation**
2011-12-13 13:04:42 +08:00
2011-12-28 02:43:38 +08:00
* Ctrl-H and Ctrl-L - left an right on tabs
2011-12-18 05:27:01 +08:00
* Use Cmd-1..Cmd-0 to switch to a specific tab number (like iTerm) - and tabs have been set up to show numbers
2011-12-18 06:11:05 +08:00
**Window Navigation**
2011-12-18 05:27:01 +08:00
* H L I M - to move left, right, up, down between windows
2011-12-23 03:55:18 +08:00
* Q - Intelligent Window Killer. Close window (wincmd c) if there are multiple windows to same buffer, or kill the buffer (bwipeout) if this is the last window into it.
2011-12-18 05:27:01 +08:00
2011-12-18 06:11:05 +08:00
**Splits**
2011-12-18 05:27:01 +08:00
2011-12-16 16:04:14 +08:00
* vv - vertical split (Ctrl-w,v)
* ss - horizontal split (Ctrl-w,s)
2011-12-21 15:48:33 +08:00
* ,, - zoom a window to max size and again to unzoom it (ZoomWin plugin, usually C-w,o)
2012-01-21 10:43:49 +08:00
* ,qo - open quickfix window (this is where output from GitGrep goes)
* ,qc - close quickfix
2011-12-21 15:48:33 +08:00
**NERDTree Project Tree**
2012-01-21 10:01:06 +08:00
* Cmd-N - NERDTree toggle
2011-12-21 15:48:33 +08:00
* Ctrl-\ - Show current file tree
2011-12-16 14:20:51 +08:00
2011-12-18 06:11:05 +08:00
**Utility**
2011-12-13 13:04:42 +08:00
2012-01-21 10:46:57 +08:00
* ,ig - toggle visual indentation guides
2012-01-03 04:27:36 +08:00
* ,cf - Copy Filename of current file into system (not vi) paste buffer
2011-12-16 14:20:51 +08:00
* ,cc - (Current command) copies the command under your cursor and executes it in vim. Great for testing single line changes to vimrc.
* ,yw - yank a word from anywhere within the word (so you don't have to go to the beginning of it)
* ,ow - overwrite a word with whatever is in your yank buffer - you can be anywhere on the word. saves having to visually select it
2012-01-07 02:31:24 +08:00
* ,w - strip trailing whitespaces
2011-12-18 17:38:03 +08:00
* sj - split a line such as a hash {:foo => {:bar => :baz}} into a multiline hash (j = down)
* sk - unsplit a link (k = up)
2011-12-21 15:48:33 +08:00
* Cmd-Shift-A - align things (type a character/expression to align by, works in visual mode or by itself)
2011-11-18 06:50:58 +08:00
2011-12-21 15:48:33 +08:00
**Comments**
2011-12-16 16:30:43 +08:00
2011-12-21 15:48:33 +08:00
* Cmd-/ - toggle comments (usually gcc from tComment)
2012-01-03 04:27:36 +08:00
* gcp (comment a paragraph)
2011-12-16 16:30:43 +08:00
2011-12-07 15:06:13 +08:00
Included vim plugins
---
2011-12-18 06:11:05 +08:00
**Navigation**
2011-12-07 17:02:20 +08:00
* NERDTree - everyone's favorite tree browser
* NERDTree-tabs - makes NERDTree play nice with MacVim tabs so that it's on every tab
2012-01-21 10:46:57 +08:00
* ShowMarks - creates a visual gutter to the left of the number column showing you your marks
* EasyMotion - hit ,,w (forward) or ,,b (back) and watch the magic happen. just type the letters and jump directly to your target - in the provided vimrc the keys are optimized for home and upper row, no pinkies
2011-12-07 17:40:44 +08:00
* LustyJuggler/Explorer - hit B, type buf name to match a buffer, or type S and use the home row keys to select a buffer
2011-12-13 12:42:54 +08:00
* TagList - hit ,T to see a list of methods in a class (uses ctags)
2011-12-21 15:48:33 +08:00
* CommandT - ,t to find a file
2011-12-16 16:30:43 +08:00
* VimBookmarks - toggle an anonymous bookmark ,bb and go thru them ,bn ,bp and clear them ,bc
2012-01-21 10:46:57 +08:00
* TabMan - hit ,mt to see all tabs and buffers in a tree. Easy to navigate and close.
2011-12-07 17:02:20 +08:00
2011-12-18 06:11:05 +08:00
**Git**
2011-12-07 17:02:20 +08:00
2011-12-07 16:32:08 +08:00
* fugitive - "a git wrapper so awesome, it should be illegal..". Try Gstatus and hit '-' to toggle files. Git 'd' to see a diff. Learn more: http://vimcasts.org/blog/2011/05/the-fugitive-series/
2011-12-19 17:19:03 +08:00
* extradite - use :Extradite to get a really great git log browser. Only works when you have a file open.
2011-12-07 15:06:13 +08:00
* GitGrep - much better than the grep provided with fugitive; use :GitGrep or hit K to grep current word
2011-12-07 17:02:20 +08:00
2011-12-18 06:11:05 +08:00
**Colors**
2011-12-07 17:02:20 +08:00
* AnsiEsc - inteprets ansi color codes inside log files. great for looking at Rails logs
* solarized - a color scheme scientifically calibrated for awesomeness (including skwp mods for ShowMarks)
* csapprox - helps colors to be represented correctly on terminals (even though we expect to use MacVim)
2011-12-18 06:11:05 +08:00
**Coding**
2011-12-07 17:02:20 +08:00
* tComment - gcc to comment a line, gcp to comment blocks, nuff said
* sparkup - div.foo#bar - hit ctrl-e, expands into < code >< div class = 'foo' id # bar /></ code > , and that's just the beginning
2011-12-07 18:00:46 +08:00
* rails.vim - syntax highlighting, gf (goto file) enhancements, and lots more. should be required for any rails dev
2011-12-08 18:02:21 +08:00
* ruby.vim - lots of general enhancements for ruby dev
* necomplcache - intelligent and fast complete as you type, and added Command-Space to select a completion (same as Ctrl-N)
* snipMate - offers textmate-like snippet expansion + scrooloose-snippets . try hitting TAB after typing a snippet
2012-01-12 03:07:32 +08:00
* jasmine.vim - support for jasmine javascript unit testing, including snippets for it, before, etc..
2012-01-23 10:47:55 +08:00
* vim-coffeescript - support for coffeescript, highlighting
* vim-stylus - support for stylus css language
2011-12-20 17:58:23 +08:00
**TextObjects**
The things in this section provide new "objects" to work with your standard verbs such as yank/delete/change/=(codeformat), etc
* textobj-rubyblock - ruby blocks become vim textobjects denoted with 'r'. try var/vir to select a ruby block, dar/dir for delete car/cir for change, =ar/=ir for formatting, etc
* vim-indentobject - manipulate chunks of code by indentation level (great for yaml) use vai/vii to select around an indent block, same as above applies
* argtextobj - manipulation of function arguments as an "a" object, so vaa/via, caa/cia, daa/dia, etc..
* textobj-datetime - gives you 'da' (date), 'df' (date full) and so on text objects. useable with all standard verbs
* vim-textobj-entire - gives you 'e' for entire document. so vae (visual around entire document), and etc
* vim-textobj-rubysymbol - gives you ':' textobj. so va: to select a ruby symbol. da: to delete a symbol..etc
2012-01-22 04:45:53 +08:00
* vim-textobj-function - gives you 'f' textobj. so vaf to select a function
2012-01-21 11:21:27 +08:00
* next-textobject - from Steve Losh, ability to use 'n' such as vinb (visual inside (n)ext set of parens)
2011-12-07 17:02:20 +08:00
2011-12-18 06:11:05 +08:00
**Utils**
2011-12-07 17:02:20 +08:00
2012-01-03 04:27:36 +08:00
* SplitJoin - easily split up things like ruby hashes into multiple lines or join them back together. Try :SplitjoinJoin and :SplitjoinSplit or use the bindings sj(split) and sk(unsplit) - mnemonically j and k are directions down and up
2011-12-18 17:38:03 +08:00
* tabularize - align code effortlessly by using :Tabularize /[character] to align by a character, or try the keymaps
2011-12-18 05:27:01 +08:00
* yankring - effortless sanity for pasting. every time you yank something it goes into a buffer. after hitting p to paste, use ctrl-p or ctrl-n to cycle through the paste options. great for when you accidentally overwrite your yank with a delete
2011-12-08 18:02:21 +08:00
* surround - super easy quote and tag manipulation - ysiw" - sourround inner word with quotes. ci"' - change inner double quotes to single quotes, etc
2011-12-07 17:40:44 +08:00
* greplace - use :Gsearch to find across many files, replace inside the changes, then :Greplace to do a replace across all matches
2011-12-07 16:32:08 +08:00
* ConqueTerm - embedded fully colorful shell inside your vim
2012-01-21 10:46:57 +08:00
* vim-ruby-conque - helpers to run ruby,rspec,rake within ConqueTerm - use ,rr (ruby), ,ss (rspec), ,ll (rspec line), ,RR (rake)
2011-12-21 15:48:33 +08:00
* vim-rspec - really clean and colorful rspec output (Cmd-Shift-R) with ability to navigate directly to error; will replace vim-ruby-conque when I do a couple enhancements/bug fixes
2011-12-07 16:49:13 +08:00
* vim-markdown-preview - :Mm to view your README.md as html
2011-12-08 18:02:21 +08:00
* html-escape - hit ctrl-h to escape html
2011-12-07 17:02:20 +08:00
* ruby-debug-ide - not quite working for me, but maybe it will for you. supposedly a graphical debugger you can step through
2011-12-13 12:55:35 +08:00
* Gundo - visualize your undos - pretty amazing plugin. Hit ,u with my keymappings to trigger it, very user friendly
2011-12-16 15:09:50 +08:00
* slime - use ctrl-c,ctrl-c to send text to a running irb/pry/console. To start the console, you must use screen with a named session: "screen -S [name] [cmd]", ex: "screen -S pry pry"
2012-01-21 10:46:57 +08:00
* vim-indent-guides - visual indent guides, off by default
2011-12-07 17:02:20 +08:00
2011-12-18 06:11:05 +08:00
**General enhancements that don't add new commands**
2011-12-07 17:12:42 +08:00
2011-12-18 05:27:01 +08:00
* IndexedSearch - when you do searches will show you "Match 2 of 4" in the status line
2012-01-03 04:27:36 +08:00
* delimitMate - automatically closes quotes
2011-12-07 17:12:42 +08:00
* syntastic - automatic syntax checking when you save the file
2011-12-07 17:50:46 +08:00
* repeat - adds '.' (repeat command) support for complex commands like surround.vim. i.e. if you perform a surround and hit '.', it will Just Work (vim by default will only repeat the last piece of the complex command)
2011-12-08 18:02:21 +08:00
* endwise - automatically closes blocks (if/end)
* autotag - automatically creates tags for fast sourcecode browsing. use ctrl-[ over a symbol name to go to its definition
* matchit - helps with matching brackets, improves other plugins
2011-12-30 09:35:45 +08:00
* sass-status - decorates your status bar with full nesting of where you are in the sass file
2011-12-07 17:12:42 +08:00
2011-12-07 15:45:08 +08:00
Adding your own vim plugins
---
2011-12-08 12:54:03 +08:00
YADR comes with a dead simple plugin manager that just uses git submodules, without any fancy config files.
2011-12-07 15:45:08 +08:00
2011-12-08 12:54:03 +08:00
yav -u https://github.com/airblade/vim-rooter
2011-12-07 15:45:08 +08:00
2011-12-08 12:54:03 +08:00
You can update all the plugins easily:
2011-12-07 15:45:08 +08:00
2011-12-18 05:27:01 +08:00
yuv
2011-12-08 14:49:58 +08:00
Delete a plugin (Coming Soon)
ydv -p airblade-vim-rooter
2011-12-07 15:45:08 +08:00
2011-12-08 12:54:03 +08:00
The aliases (yav=yadr vim-add-plugin) and (yuv=yadr vim-update-all-plugins) live in the aliases file.
2011-12-07 15:45:08 +08:00
You can then commit the change. It's good to have your own fork of this project to do that.
2011-12-07 15:06:13 +08:00
2011-11-18 06:50:58 +08:00
Setup for Git
---
2011-12-18 06:11:05 +08:00
**To use the gitconfig (some of the git bash aliases rely on my git aliases)**
2011-11-18 06:50:58 +08:00
ln -s ~/.dotfiles/gitconfig ~/.gitconfig
2011-12-09 15:40:18 +08:00
Since the gitconfig doesn't contain the user info, I recommend using env variables.
2011-12-18 06:11:05 +08:00
**Put the following in your ~/.secrets file which is automatically referenced by the provided zshrc:**
2011-12-09 15:40:18 +08:00
2012-01-25 02:34:34 +08:00
# Set your git user info
export GIT_AUTHOR_NAME='You Name'
export GIT_AUTHOR_EMAIL='you@domain.com'
export GIT_COMMITTER_NAME='Your Name'
export GIT_COMMITTER_EMAIL='you@domain.com'
# Optionally, set your GitHub credentials
export GITHUB_USER='your_user_name'
export GITHUB_TOKEN='your_github_token'
2011-12-09 15:40:18 +08:00
2011-12-18 06:11:05 +08:00
**Some of the customizations provided include:**
2011-12-07 13:57:45 +08:00
* git l - a much more usable git log
* git b - a list of branches with summary of last commit
* git r - a list of remotes with info
* git t - a list of tags with info
* git nb - a (n)ew (b)ranch - like checkout -b
* git cp - cherry-pick -x (showing what was cherrypicked)
* git changelog - a nice format for creating changelogs
2012-01-03 04:27:36 +08:00
* Some sensible default configs, such as improving merge messages, push only pushes the current branch, removing status hints, and using mnemonic prefixes in diff: (i)ndex, (w)ork tree, (c)ommit and (o)bject
2011-12-07 13:57:45 +08:00
* Slightly imrpoved colors for diff
* git unstage (remove from index) and git uncommit (revert to the time prior to the last commit - dangerous if already pushed) aliases
2011-11-18 06:50:58 +08:00
OSX Hacks
---
The osx file is a bash script that sets up sensible defaults for devs and power users
2011-11-19 00:10:06 +08:00
under osx. Read through it before running it. To use:
./osx
2011-12-07 13:57:45 +08:00
These hacks are Lion-centric. May not work for other OS'es. My favorite mods include:
2011-11-19 00:10:06 +08:00
2011-12-07 13:57:45 +08:00
* Ultra fast key repeat rate (now you can scroll super quick using j/k)
2012-01-03 04:27:36 +08:00
* No disk image verification (downloaded files open quicker)
2011-12-07 13:57:45 +08:00
* Display the ~/Library folder in finder (hidden in Lion)
2011-11-18 06:40:21 +08:00
2012-01-03 04:27:36 +08:00
Other recommended OSX tools
2011-11-19 02:53:07 +08:00
---
2011-12-07 13:57:45 +08:00
* NValt - Notational Velocity alternative fork - http://brettterpstra.com/project/nvalt/ - syncs with SimpleNote
* Vimium for Chrome - vim style browsing. The 'f' to type the two char alias of any link is worth it.
* QuickCursor - gives you Apple-Shift-E to edit any OSX text field in vim.
2011-12-19 05:08:35 +08:00
* brew install autojump - will track your commonly used directories and let you jump there. With the zsh plugin you can just type 'j [dirspec]', a few letters of the dir you want to go to.]'
2011-11-19 02:53:07 +08:00
2011-11-18 05:45:33 +08:00
Credits
2011-12-08 12:54:03 +08:00
---
2011-12-16 14:41:56 +08:00
2011-11-18 05:45:33 +08:00
I can't take credit for all of this. The vim files are a combination of
work by tpope, scrooloose, and many hours of scouring blogs, vimscripts,
2011-12-16 14:41:56 +08:00
and other places for the cream of the crop of vim awesomeness.
2011-12-18 06:40:58 +08:00
* http://ethanschoonover.com/solarized - a scientifically calibrated color scheme
2011-12-16 14:41:56 +08:00
* https://github.com/astrails/dotvim
* https://github.com/carlhuda/janus
* https://github.com/tpope
* https://github.com/scrooloose
* https://github.com/kana
* https://github.com/robbyrussell
* https://github.com/nelstrom
And everything that's in the modules included in vim/bundle of course.
Please explore these people's work.
2011-11-18 05:45:33 +08:00
2011-12-06 16:40:44 +08:00
COMING SOON
2011-12-08 12:54:03 +08:00
---
2011-12-07 13:57:45 +08:00
* Better isolation of customizations in smaller chunks, maybe as plugins
2012-01-03 04:27:36 +08:00
* Automatic setup script to symlink all dotfiles, or just some selectively
2011-11-18 05:45:33 +08:00
For more tips and tricks
2011-12-08 12:54:03 +08:00
---
2011-11-18 06:40:21 +08:00
Follow my blog: http://yanpritzker.com
2012-01-25 02:34:34 +08:00