mirror of
https://github.com/SpaceVim/SpaceVim.git
synced 2025-02-19 09:03:44 +08:00
96 lines
4.7 KiB
Markdown
96 lines
4.7 KiB
Markdown
|
# 👣 gina.vim
|
||
|
|
||
|
data:image/s3,"s3://crabby-images/748bc/748bc4976f18deb7adc15d8d09a0258473d1347c" alt="Version 1.0"
|
||
|
data:image/s3,"s3://crabby-images/9566b/9566b6cab03de7252cd391f37b7c03a4a71ddad4" alt="Support Vim 8.1 or above"
|
||
|
data:image/s3,"s3://crabby-images/ccc67/ccc67a5351ffc92ea3826f112689d8e0cdb2b360" alt="Support Neovim 0.4 or above"
|
||
|
data:image/s3,"s3://crabby-images/ee5d1/ee5d17dc67d9204c0490ddd24a44f9e0c470e47f" alt="Support Git 2.25 or above"
|
||
|
[data:image/s3,"s3://crabby-images/e0e92/e0e92f0a61bb4f00c44f5acd75ea236833d492b7" alt="Powered by vital.vim"](https://github.com/vim-jp/vital.vim)
|
||
|
[data:image/s3,"s3://crabby-images/cd905/cd905e0a2ca7bdcc1e24610cd29a025951ccf9ef" alt="MIT License"](LICENSE)
|
||
|
[data:image/s3,"s3://crabby-images/c7f4d/c7f4ddd02d97a9e3cde68360f548da7b325b3a74" alt="Doc"](doc/gina.txt)
|
||
|
[data:image/s3,"s3://crabby-images/e505b/e505bb9f7efe43d6a8c68d11b2375d5848653992" alt="Doc (dev)"](doc/gina-develop.txt)
|
||
|
|
||
|
[data:image/s3,"s3://crabby-images/e4203/e42034be408dadba71356acecd6013ae670336a1" alt="reviewdog"](https://github.com/lambdalisue/gina.vim/actions?query=workflow%3Areviewdog)
|
||
|
[data:image/s3,"s3://crabby-images/79fb4/79fb48e530f7f55a6e89a3d4767beffe9beb4cf7" alt="vim"](https://github.com/lambdalisue/gina.vim/actions?query=workflow%3Avim)
|
||
|
[data:image/s3,"s3://crabby-images/472f3/472f3de778f9e64171028da93484a19d4a211074" alt="neovim"](https://github.com/lambdalisue/gina.vim/actions?query=workflow%3Aneovim)
|
||
|
|
||
|
gina.vim (gina) is a plugin to asynchronously control git repositories.
|
||
|
|
||
|
## Presentation
|
||
|
|
||
|
[data:image/s3,"s3://crabby-images/b8313/b8313abf822efa6675a4af31f58df431d080544d" alt="You've been Super Viman. After this talk, you could say you are Super Viman 2 -- Life with gina.vim"](https://www.youtube.com/watch?v=zkANQ9l7YDM)
|
||
|
|
||
|
I've talked about what the gina.vim is in [VimConf2017](http://vimconf.vim-jp.org/2017/) ([Slide](https://lambdalisue.github.io/vimconf2017/assets/player/KeynoteDHTMLPlayer.html)). Check it out if you would like to feel what the gina.vim is.
|
||
|
|
||
|
## Usage
|
||
|
|
||
|
The following is a schematic image of general working-flow with gina.
|
||
|
|
||
|
```
|
||
|
┌─────┬──────────┐
|
||
|
│ │ │
|
||
|
#DIRTY# │ ▼
|
||
|
▲ │ :Gina status │ << : stage
|
||
|
│ │ │ │ >> : unstage
|
||
|
│ │ │ │ -- : toggle
|
||
|
:write │ #STAGED# │ == : discard
|
||
|
▲ │ │ │ pp : patch
|
||
|
│ ├──────────┤ │ dd : diff
|
||
|
│ │ ▼
|
||
|
#CLEAN# │ :Gina commit │ ! : switch --amend
|
||
|
│ │ │ │ :w : save cache
|
||
|
│ ▼ │ │ :q : commit changes (confirm)
|
||
|
└────────────────┘ │ :wq : commit changes (immediate)
|
||
|
```
|
||
|
|
||
|
So basically user would
|
||
|
|
||
|
1. Edit contents in a git repository
|
||
|
2. Stage changes with `:Gina status`
|
||
|
3. Commit changes with `:Gina commit`
|
||
|
|
||
|
See `:h gina-usage` for advance usage. Gina provides a lot more features.
|
||
|
|
||
|
## Pros.
|
||
|
|
||
|
- A git detection is fast and accurate
|
||
|
- It does not require `git` process so incredibly fast
|
||
|
- Used in [lambdalisue/vim-gita][], for several years
|
||
|
- Commands are asynchronously performed
|
||
|
- Users don't have to wait `:Gina push` (`git push`)
|
||
|
- Asynchronous feature in Neovim is great. `:Gina log` (`git log`) on **Linux** repository won't freeze Neovim
|
||
|
- Single command. Users do not need to remember tons of commands
|
||
|
- `:Gina {command}` will execute a gina command or a git raw command asynchronously
|
||
|
- `:Gina! {command}` will execute a git raw command asynchronously
|
||
|
- `:Gina!! {command}` will execute a git raw command in a shell (mainly for `:Gina!! add -p` or `:Gina!! rebase -i`)
|
||
|
- Action based. Users do not need to remember tons of mappings
|
||
|
- `?` to see the help
|
||
|
- `a` to select an action to perform (complete with `<Tab>`)
|
||
|
- `.` to repeat previous action
|
||
|
- All action can map to an actual keymap
|
||
|
- Author tried to follow Vim's flavor
|
||
|
- No mapping for `ee` or whatever which conflicts with Vim's native mappings (like vim-gita does...)
|
||
|
- Customizable
|
||
|
- Users can define action aliases and mappings
|
||
|
- Users can define default options and aliases of command
|
||
|
- More
|
||
|
- Tested on all major platforms
|
||
|
- Powered by [vim-jp/vital.vim][], mean that the things are unit tested
|
||
|
- Gina add some behaviour test as well
|
||
|
|
||
|
[lambdalisue/vim-gita]: https://github.com/lambdalisue/vim-gita
|
||
|
[vim-jp/vital.vim]: https://github.com/vim-jp/vital.vim
|
||
|
|
||
|
## Contribution
|
||
|
|
||
|
Any contribution including documentations are welcome.
|
||
|
|
||
|
Contributers should install [thinca/vim-themis][] to run tests before sending a PR if they applied some modification to the code.
|
||
|
PRs which does not pass tests won't be accepted.
|
||
|
|
||
|
[thinca/vim-themis]: https://github.com/thinca/vim-themis
|
||
|
|
||
|
## License
|
||
|
|
||
|
The code in gina.vim follows MIT license texted in [LICENSE](./LICENSE).
|
||
|
Contributors need to agree that any modifications sent in this repository follow the license.
|