2020-11-07 16:26:22 +08:00
# Ruilisi dotfiles
2020-07-11 17:00:51 +08:00
2021-03-12 14:52:55 +08:00
Forked from https://github.com/skwp/dotfiles
2021-04-17 15:36:04 +08:00
# Get started
## Requirements
2021-03-02 11:22:10 +08:00
* `zsh` , `tmux` , `vim` , `ag` are installed and zsh is set as your login shell:
2020-11-07 16:26:22 +08:00
```sh
chsh -s $(which zsh)
2012-01-25 03:53:44 +08:00
```
2021-03-02 11:22:10 +08:00
* `Python 3` and `pynvim` as some layers(`denite`) can't be loaded if they are missing
2021-03-04 16:48:55 +08:00
```sh
2021-03-02 11:22:10 +08:00
python3 -m pip install --user --upgrade pynvim
```
2012-01-25 03:53:44 +08:00
2021-04-17 15:36:04 +08:00
## Install
2020-07-11 17:00:51 +08:00
2020-11-07 16:26:22 +08:00
```sh
bash -c "`curl -fsSL https://raw.githubusercontent.com/ruilisi/dotfiles/master/install.sh`"
2013-04-07 18:17:48 +08:00
```
2021-03-04 16:48:55 +08:00
Or
```sh
2021-07-29 00:24:28 +08:00
bash -c "`curl -fsSL https://xiemala.com/ruilisi/dotfiles/raw/branch/master/install.sh`"
2020-07-11 17:00:51 +08:00
```
2021-04-17 15:36:04 +08:00
## Upgrade
2021-03-04 16:48:55 +08:00
```sh
2012-09-29 01:38:59 +08:00
cd ~/.yadr
2013-12-16 04:11:22 +08:00
git pull --rebase
2012-10-09 12:38:21 +08:00
rake update
2012-06-07 13:14:09 +08:00
```
2021-04-17 15:36:04 +08:00
# Modules
2021-03-04 16:48:55 +08:00
## ZSH
2021-04-17 15:36:04 +08:00
* [Prezto - the zsh behind YADR's ](http://github.com/sorin-ionescu/prezto )
* [How to add your own ZSH theme ](doc/zsh/themes.md )
2020-07-11 17:00:51 +08:00
2021-04-17 15:36:04 +08:00
#### General Commands
2021-03-06 11:54:36 +08:00
- `Replace`
- `Replace s SOURCE_TEXT -d DESTINATION_TEXT -f FILE_REGEX_PATTERH --separator=SEPERATOR`
- By default, `FILE_REGEX_PATTERN` is `.*` , SEPERATOR` is `;`
- Example: `Replace -s "/api/rule" -d "/dashboard/api/rule" -f ".*.ts"`
2021-03-04 16:48:55 +08:00
- `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
- `git-set-remote $1` -set project git remote url
- `gem_source_to_taobao` -set ruby gem source to taobao
- `docker_rm_all` -delete all docker images
- `Replace $1 $2` -replcae all text under current path
- `swap $1 $2` -`swap file1 file2`
- `init_db` -init rails project database
- `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
2011-12-18 06:11:05 +08:00
2021-04-17 15:36:04 +08:00
#### 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](https://github.com/clvv/fasd)
2021-03-04 16:48:55 +08:00
The name fasd comes from the default suggested aliases f(files), a(files/directories), s(show/search/select), d(directories).
2020-07-11 17:00:51 +08:00
2021-03-04 16:48:55 +08:00
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
2020-07-11 17:00:51 +08:00
```
2021-03-04 16:48:55 +08:00
Fasd comes with some useful aliases by default:
```sh
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
2020-07-11 17:00:51 +08:00
```
2021-03-04 16:48:55 +08:00
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:
2011-11-18 05:45:33 +08:00
2021-03-04 16:48:55 +08:00
```sh
mv update.html `d www`
cp `f mov` .
```
2012-09-27 02:05:28 +08:00
2021-03-04 16:48:55 +08:00
## Tmux
2021-04-17 15:36:04 +08:00
#### Settings
2020-07-11 17:00:51 +08:00
2020-11-19 11:32:46 +08:00
`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` .
2021-04-17 15:36:04 +08:00
#### Shortcuts
2021-03-04 16:48:55 +08:00
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
2021-07-29 00:57:31 +08:00
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
2021-03-04 16:48:55 +08:00
> `C` is short for `Ctrl`
Press `PRE [` to enter Scroll Mode
2012-05-19 05:08:46 +08:00
2021-03-04 16:48:55 +08:00
Shortcut | Function |
:--------|:---------|
`Shift-V` | Select Text|
`Enter` | Copy Text |
`]` | Paste text copied from scroll mode |
2020-07-11 17:00:51 +08:00
2021-03-04 16:48:55 +08:00
## Vim & Spacevim
* `<L>` : Short for `<localleader>` , which is `\` in our setup
2020-07-11 17:00:51 +08:00
2021-03-04 16:48:55 +08:00
**Defined by Us**
2020-07-11 17:00:51 +08:00
2021-04-17 15:36:04 +08:00
#### Basic
[Here ](doc/vim-basic.md )
2020-07-11 17:00:51 +08:00
2021-04-17 15:36:04 +08:00
#### Shortcuts
2021-03-12 14:52:55 +08:00
**General**
2021-02-09 23:11:22 +08:00
Shortcut | Function
2020-11-20 08:39:27 +08:00
:-------:|:--------:
2021-03-04 16:48:55 +08:00
C-v | Enter visual mode
C-x C-v | Paste text from system clipboard
< L > tp | Toggle paste
SPC f v d| Open configuration file
SPC g . | Enter version control transient-state
SPC l p | Preview markdown
2021-03-12 14:52:55 +08:00
**Typescript**
2021-08-04 12:59:14 +08:00
2021-03-12 14:52:55 +08:00
Shortcut | Function
:-------:|:--------:
SPC l p | Definitaion Preview
2021-08-04 12:59:14 +08:00
SPC l t | Type
2021-03-12 14:52:55 +08:00
SPC l e | Rename
SPC l d | Doc
2021-08-04 12:59:14 +08:00
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
2021-12-31 15:32:39 +08:00
**Git Blame**
2021-08-04 12:59:14 +08:00
Shortcut | Function
:-------:|:--------:
< leader > b | Togggle git blame info at the end of current line
2021-12-31 15:32:39 +08:00
< leader > s | See Git Blame information in the status bar for the currently selected line.
2021-08-04 12:59:14 +08:00
< SPC > gb | Open git blame window
2021-03-12 14:52:55 +08:00
2021-04-17 15:36:04 +08:00
#### markdown
2021-08-04 12:59:14 +08:00
2021-03-04 16:48:55 +08:00
* Install `prettier` : `yarn global add prettier` or `npm install --global prettier`
* Open vim and enter command: `:SPUPdate`
2020-07-11 17:00:51 +08:00
2021-04-17 15:36:04 +08:00
#### Option window, window, split bar
2020-11-19 11:32:46 +08:00
- `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` 。
2021-03-04 16:48:55 +08:00
- `Q` - Enter Ex mode
2020-11-19 11:32:46 +08:00
- `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
2020-07-11 17:00:51 +08:00
2021-03-12 14:52:55 +08:00
#### Typescript
2021-06-14 23:36:35 +08:00
* Fix `SpaceVim Unknown function: TSOnBufEnter`
2021-03-12 14:52:55 +08:00
* References
* https://github.com/SpaceVim/SpaceVim/issues/1800
* https://github.com/SpaceVim/SpaceVim/issues/3221
* Resolution steps
* Delete cache rm -rf ~/.cache/vimfiles/.cache
* Open vim run `:CheckHealth` check the current vim status, and fix any errors.
2021-04-26 13:55:50 +08:00
* Install pip for `python3` if not: `curl https://bootstrap.pypa.io/get-pip.py | python3`
* `pip install neovim`
2021-07-29 00:24:28 +08:00
* `npm install -g neovim typescript`
2021-04-26 13:55:50 +08:00
* Run `:UpdateRemotePlugins` in vim and reopen vim
2021-06-14 23:36:35 +08:00
* If plugin `nvim-typescript` is not installed successfully(`vim` -> `:SPUpdate` ), try following steps one by one until succeeded:
1. Add `call dein#reinstall(['nvim-typescript'])` to `~/.local/share/nvim/rplugin.vim` , reopen vim and wait for the `nvim-typescript` plugin to install
2. Install it manually:
```bash
cd ~/.cache/vimfiles/repos/github.com/mhartington/
rm -rf nvim-typescript
git clone https://github.com/mhartington/nvim-typescript
cd nvim-typescript
npm config set registry=https://registry.npmjs.com/
./install.sh
```
2020-07-11 17:00:51 +08:00
2021-03-12 14:52:55 +08:00
#### Rails & Ruby
2020-11-19 11:32:46 +08:00
- `,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: true` tag 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).
2020-07-11 17:00:51 +08:00
2014-02-16 11:25:17 +08:00
#### Vim Dev
2020-11-19 11:32:46 +08:00
- `,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.
2020-07-11 17:00:51 +08:00
2020-11-19 11:32:46 +08:00
#### 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.
2020-11-16 18:54:12 +08:00
2020-11-19 11:32:46 +08:00
- `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
2020-11-16 18:54:12 +08:00
2021-03-04 16:48:55 +08:00
## iTerm
2020-07-11 17:00:51 +08:00
2021-03-04 16:48:55 +08:00
### iTerm Solarized Colors
2012-01-25 02:53:58 +08:00
2021-03-04 16:48:55 +08:00
YADR will install the Solarized color scheme into iTerm. You can choose Solarized Dark in Profiles => Colors => Load Presets.
2020-07-11 17:00:51 +08:00
2021-03-04 16:48:55 +08:00
## [Homebrew](http://mxcl.github.com/homebrew/)
2015-05-05 03:20:49 +08:00
2014-02-16 11:21:08 +08:00
2021-03-04 16:48:55 +08:00
Homebrew is a missing OSX package management system, and it will be installed automatically.
2014-02-16 11:21:08 +08:00
2021-03-04 16:48:55 +08:00
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.