/dotar

All-in-one dev configuration for your mac/linux

Primary LanguageRubyBSD 2-Clause "Simplified" LicenseBSD-2-Clause

Dotar is an all-in-one dev configuration for your mac/linux which includes setup for zsh, spacevim(nvim), tmux and many more

The story

Dotar got its name by the combination of dot and tar which means package(tar) dotfiles togeter.

Get started

Requirements

  • zsh, tmux, vim, ag are installed and zsh is set as your login shell:
chsh -s $(which zsh)
  • Python 3 and pynvim as some layers(denite) can't be loaded if they are missing
python3 -m pip install --user --upgrade pynvim

Install

bash -c "`curl -fsSL https://raw.githubusercontent.com/ruilisi/dotar/master/install.sh`"

Upgrade

cd ~/.yadr
git pull --rebase
rake update

Modules

Zsh Commands

Command Args Description
swap F1 F2 swap file F1 with file F2
Replace doc Replace text recursively
Replace options:
  -f            File regex pattern
  -s            Source pattern
  -d            Destination pattern
  -r            Remove line
  --regex       Match pattern with regex
  --seperator=  Seperator, # by default
  -h            Display this message"

Editing

Shortcut Alias
Ctrl-R Vim mode and bash style historical anti-query
ae Edit alias
ar Reload alias
ESC C-x C-e Edit current command line in vim

Network

Command Description
test-port PORT test whether PORT is opened
intercept-request-hosts intercept requests and show hosts
host-ip show host ip of your system

System

Command Description
yell print the script name and all arguments to stderr
die does the same as yell, but exits with a non-0 exit status, which means "fail".
try uses the
list-large-files DIR list large files sort by reversed order of size and print size in the order of KB, MB, GB

String

Command Description
random-hex print random hex
random-string print random string of alphabets a-zA-Z0-9
contains str1 str2 ... target

Git

YADR will take over your ~/.gitconfig, so if you want to store your git username and other settings, please put them in ~/.gitconfig.user

We recommend setting your user information in this file. In addition, you can set your environment variables appropriately in your ~/.secrets.

Command Alias
ga git add
gb git branch
gbc or gnb git checkout -b
gbs git show-branch
gc git commit --verbose
gco git checkout
gcp git cherry-pick --ff
gd git diff
gf git fetch
gfc git clone
gfm git pull
gfr git pull --rebase
gl git log
gpc git push --set-upstream origin "$(git-branch-current 2> /dev/null)"
gr git rebase
gra git rebase --abort
grc git rebase --continue
grs git rebase --skip
gsd git stash drop
gsl git stash list
gsp git stash pop
gst git stash

Other

  • secure_source -source ~/.yadr/zsh/function.zsh file, let function.zsh modify work immediately in current window
  • pp $1 -useage:pp xx, grep process by name
  • set_proxy -set terminal proxy use http proxy
  • set_vagrant_proxy -set terminal proxy use vagrant http proxy
  • set_ss_proxy -set terminal proxy use socks proxy
  • unset_proxy -cancel all proxy
  • post $1 $2 -curl POST with application/json
  • docker_rm_all -delete all docker images
  • kexec -execute k8s pod by regex pod name
  • klog -show k8s pod log by regex pod name
  • git_tag_delete -delete gtihub tag
  • git_tag_add -add gtihub tag
  • dc -alias of docker-compose

The name fasd comes from the default suggested aliases f(files), a(files/directories), s(show/search/select), d(directories).

Some situations where you can type in the command on the left and fasd will "expand" your command into the right side.

  v def conf       =>     vim /some/awkward/path/to/type/default.conf
  j abc            =>     cd /hell/of/a/awkward/path/to/get/to/abcdef
  m movie          =>     mplayer /whatever/whatever/whatever/awesome_movie.mp4
  o eng paper      =>     xdg-open /you/dont/remember/where/english_paper.pdf
  vim `f rc lo`    =>     vim /etc/rc.local
  vim `f rc conf`  =>     vim /etc/rc.conf

Fasd comes with some useful aliases by default:

alias a='fasd -a'        # any
alias s='fasd -si'       # show / search / select
alias d='fasd -d'        # directory
alias f='fasd -f'        # file
alias sd='fasd -sid'     # interactive directory selection
alias sf='fasd -sif'     # interactive file selection
alias z='fasd_cd -d'     # cd, same functionality as j in autojump
alias zz='fasd_cd -d -i' # cd with interactive selection

Fasd will smartly detect when to display a list of files or just the best match. For instance, when you call fasd in a subshell with some search parameters, fasd will only return the best match. This enables you to do:

mv update.html `d www`
cp `f mov` .

Tmux

Settings

tmux.conf provides some reasonable default settings for tmux on Mac OS, such as a powerful status bar and VIM keyboard bindings. You can modify the configuration in ~/.tmux.conf.user.

Shortcuts

Prefix is defined as C-a(PRE for short)

Shortcut Function
C-h(jkl) ←(↓↑→)Move pane
PRE c Craete a new pane
PRE s Split panes up and down
PRE v Split panes left and right
PRE x Kill pane
PRE h(jkl) ←(↓↑→)Move dividing line
PRE , Rename window
PRE d Exit Session
PRE D Exit Session
PRE 1 Enter pane 1
PRE >/< Cheatsheet
PRE {/} Move pane to previous/next position
PRE C-o rotate window ‘up’ (i.e. move all panes)
PRE M-o rotate window ‘down’
PRE z Zoom/Unzoom
PRE m Mark
PRE ! Move the current pane into a new separate
PRE o Go to the next pane (cycle through all of them)
PRE ; Go to the ‘last’ (previously used) pane

C is short for Ctrl

Press PRE [ to enter Scroll Mode

Shortcut Function
Shift-V Select Text
Enter Copy Text
] Paste text copied from scroll mode

Vim & Spacevim

  • <L>: Short for <localleader>, which is \ in our setup

Defined by Us

Basic

Here

Shortcuts

General

Shortcut Function
C-v Enter visual mode
C-x C-v Paste text from system clipboard
tp Toggle paste
SPC f v d Open configuration file
SPC g . Enter version control transient-state
SPC l p Preview markdown

Typescript

Shortcut Function
SPC l p Definitaion Preview
SPC l t Type
SPC l e Rename
SPC l d Doc
g d Go to definition
SPC e L List checkers

Tab

Shortcut Function
\[1-9] Open tab 1-9
SPC t t Open tab management window
SPC w F Open a new tab
SPC w o Switch tab

History

Shortcut Function
F7 Undo history

Debug

Shortcut Function
SPC h I Show Debug Info

Git Blame

Shortcut Function
b Togggle git blame info at the end of current line
s See Git Blame information in the status bar for the currently selected line.
gb Open git blame window

markdown

  • Install prettier: yarn global add prettier or npm install --global prettier
  • Open vim and enter command: :SPUPdate

Option window, window, split bar

  • Ctrl-h,l,j,k - use to move to left、right、top、bottom commpartment. This is still valid when vim and the split bar are together, thanks to vim-tmux-navigator
  • Q - Enter Ex mode
  • vv - Vertical separation (Ctrl-w,v)
  • ss - Horizontal separation (Ctrl-w,s)
  • ,qo - Open quickfix window (The output of grep will go to this window)
  • ,qc - close quickfix

Rails & Ruby

  • ,vv & ,cc to switch between view and controller-they are the mappings corresponding to :Rcontroller and :Rview. Explore: R family commands can learn more about the fun of rails.vim!
  • ,rs & ,rl to run rspec or a spec line in iTerm (check the iTerm window for information).
  • ,tt Add now: truetag to a block of the spec file, and then test the block by rspec --tag=now.
  • ,ss & ,sl To achieve the same thing, by using spring rspec, one can make your Rails specs faster, by caching Rails env (must have spring gem installed).

Vim Dev

  • ,vc - (Vim command) Copy the command under the cursor and run it. Very useful for testing single-line changes in vimrc.
  • ,vr - (Vim re-documented) Use the current file as a vim file to load the source.

SpaceVim Interface elements:

The interface elements of SpaceVim start with [SPC] t or [SPC] T. You can view the second-level instructions by pressing the [SPC] key in the vim window. In the same way, press the required second-level instructions and then you can check the three Level instructions to view.

  • SPC t h s - Show/hide syntax highlighting
  • SPC t n - Show/hide line number
  • SPC t h h - Highlight current line
  • SPC T m - Show/hide the menu bar (no difference is seen)
  • SPC T t - Show/hide the toolbar (don’t see the difference)
  • SPC [1-9] - Jump to the specified window
  • SPC f t - Open file tree
  • SPC p f - find files in current project
  • SPC f y - show and copy current file absolute path in the cmdline
  • SPC f S - save all files
  • SPC f o - Find current file in file tree
  • SPC f D - delete a file and the associated buffer with confirmation
  • SPC f p - search word in current project
  • SPC p / - fuzzy search for text in current project
  • SPC c l - toggle comment lines
  • SPC c p - toggle comment paragraphs

Search text

  • SPC s J - Search text under cursor in current project

Help

  • SPC h d k - Start a input prompt, Then press the key bindings you want to describe

iTerm

iTerm Solarized Colors

YADR will install the Solarized color scheme into iTerm. You can choose Solarized Dark in Profiles => Colors => Load Presets.

Homebrew is a missing OSX package management system, and it will be installed automatically.

We automatically installed some commonly used packages, such as ctags, git, macvim, hub, and RipGrep (‘rg’). Note that our auto-completion plugin requires MacVim to support Lua. The installer knows how to install it, but if you have installed it before, you need to manually delete your previous MacVim.

Frequently Asked Questions

Check FAQ