9.8 KiB
Ruilisi dotfiles
Forked from https://github.com/skwp/dotfiles
Get started
Requirements
zsh
,tmux
,vim
,ag
are installed and zsh is set as your login shell:
chsh -s $(which zsh)
Python 3
andpynvim
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/dotfiles/master/install.sh`"
Or
bash -c "`curl -fsSL https://xiemala.com/ruilisi/dotfiles/raw/branch/master/install.sh`"
Upgrade
cd ~/.yadr
git pull --rebase
rake update
Modules
ZSH
General Commands
Replace
Replace s SOURCE_TEXT -d DESTINATION_TEXT -f FILE_REGEX_PATTERH --separator=SEPERATOR
- By default,
FILE_REGEX_PATTERN
is.*
, SEPERATORis
;` - Example:
Replace -s "/api/rule" -d "/dashboard/api/rule" -f ".*.ts"
secure_source
-source~/.yadr/zsh/function.zsh
file, letfunction.zsh
modify work immediately in current windowpp $1
-useage:pp xx
, grep process by nameset_proxy
-set terminal proxy use http proxyset_vagrant_proxy
-set terminal proxy use vagrant http proxyset_ss_proxy
-set terminal proxy use socks proxyunset_proxy
-cancel all proxypost $1 $2
-curl POST with application/jsongit-set-remote $1
-set project git remote urlgem_source_to_taobao
-set ruby gem source to taobaodocker_rm_all
-delete all docker imagesReplace $1 $2
-replcae all text under current pathswap $1 $2
-swap file1 file2
init_db
-init rails project databasekexec
-execute k8s pod by regex pod nameklog
-show k8s pod log by regex pod namegit_tag_delete
-delete gtihub taggit_tag_add
-add gtihub tagdc
-alias of docker-compose
Editing Commands
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 |
Git Commands
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 |
fasd
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 , | Switch to Tmux command line mode |
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 forCtrl
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
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
ornpm 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 tovim-tmux-navigator
。Q
- Enter Ex modevv
- 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
Addnow: true
tag to a block of the spec file, and then test the block byrspec --tag=now
.,ss
&,sl
To achieve the same thing, by usingspring rspec
, one can make your Rails specs faster, by cachingRails 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 highlightingSPC t n
- Show/hide line numberSPC t h h
- Highlight current lineSPC 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 windowSPC f t
- Open file treeSPC p f
- find files in current projectSPC f y
- show and copy current file absolute path in the cmdlineSPC f S
- save all filesSPC f o
- Find current file in file treeSPC f D
- delete a file and the associated buffer with confirmationSPC f p
- search word in current projectSPC p /
- fuzzy search for text in current projectSPC c l
- toggle comment linesSPC c p
- toggle comment paragraphs
iTerm
iTerm Solarized Colors
YADR will install the Solarized color scheme into iTerm. You can choose Solarized Dark in Profiles => Colors => Load Presets.
Homebrew
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.