2018-05-15 02:09:11 +02:00
|
|
|
git-info
|
2016-12-02 22:49:45 +01:00
|
|
|
========
|
|
|
|
|
|
|
|
Exposes git repository status information to prompts.
|
|
|
|
|
|
|
|
Many thanks to [Sorin Ionescu](https://github.com/sorin-ionescu) and
|
|
|
|
[Colin Hebert](https://github.com/ColinHebert) for the original code.
|
|
|
|
|
|
|
|
Git **1.7.2** is the
|
|
|
|
[minimum required version](https://github.com/sorin-ionescu/prezto/issues/219).
|
|
|
|
|
|
|
|
Settings
|
|
|
|
--------
|
|
|
|
|
2018-12-17 20:11:16 +01:00
|
|
|
### Ignore submodules
|
2016-12-02 22:49:45 +01:00
|
|
|
|
|
|
|
Retrieving the status of a repository with submodules can take a long time.
|
2018-05-15 02:09:11 +02:00
|
|
|
So by default 'all' submodules are ignored. Optionally, 'untracked', 'dirty', or
|
|
|
|
'none' submodules can be ignored:
|
2016-12-02 22:49:45 +01:00
|
|
|
|
|
|
|
zstyle ':zim:git-info' ignore-submodules 'none'
|
|
|
|
|
2018-12-17 20:11:16 +01:00
|
|
|
### Verbose mode
|
2016-12-02 22:49:45 +01:00
|
|
|
|
|
|
|
Verbose mode uses `git status` and computes the count of indexed, unindexed and
|
|
|
|
also untracked files. It can be enabled with the following zstyle:
|
|
|
|
|
2018-05-15 02:09:11 +02:00
|
|
|
zstyle ':zim:git-info' verbose yes
|
2016-12-02 22:49:45 +01:00
|
|
|
|
2018-12-22 04:48:54 +01:00
|
|
|
In non-verbose mode, the 'untracked' context is not available (see *Main
|
|
|
|
contexts* below), and untracked files are also not considered for computing the
|
2018-05-15 02:09:11 +02:00
|
|
|
'dirty' context. Using `git status` to check for untracked files can be
|
2016-12-02 22:49:45 +01:00
|
|
|
[expensive](https://gist.github.com/sindresorhus/3898739).
|
|
|
|
|
|
|
|
Theming
|
|
|
|
-------
|
|
|
|
|
2016-12-03 13:59:37 +01:00
|
|
|
To display information about the current repository in a prompt, define your
|
|
|
|
custom styles in the `prompt_name_setup` function, where the syntax for setting
|
|
|
|
a style is:
|
2016-12-02 22:49:45 +01:00
|
|
|
|
|
|
|
zstyle ':zim:git-info:context' format 'string'
|
|
|
|
|
2018-12-17 20:11:16 +01:00
|
|
|
### Main contexts
|
2016-12-02 22:49:45 +01:00
|
|
|
|
|
|
|
| Name | Code | Description
|
2018-12-22 04:48:54 +01:00
|
|
|
| --------- | :----: | ---------------------------------------------------------
|
|
|
|
| action | %s | Special action name (see *Special action contexts* below)
|
2016-12-02 22:49:45 +01:00
|
|
|
| ahead | %A | Commits ahead of remote count
|
|
|
|
| behind | %B | Commits behind of remote count
|
2017-03-15 15:29:03 +01:00
|
|
|
| diverged | %V | Diverged commits (both ahead and behind are yield when it's not defined)
|
2016-12-02 22:49:45 +01:00
|
|
|
| branch | %b | Branch name
|
|
|
|
| commit | %c | Commit short hash (when in 'detached HEAD' state)
|
|
|
|
| clean | %C | Clean state
|
2017-03-15 15:29:03 +01:00
|
|
|
| dirty | %D | Dirty state (count with untracked files when verbose mode enabled)
|
|
|
|
| indexed | %i | Indexed files (count when verbose mode enabled)
|
|
|
|
| unindexed | %I | Unindexed files (count when verbose mode enabled)
|
2016-12-02 22:49:45 +01:00
|
|
|
| position | %p | Commits from nearest tag count (when in 'detached HEAD' state)
|
|
|
|
| remote | %R | Remote name
|
|
|
|
| stashed | %S | Stashed states count
|
2017-03-15 15:29:03 +01:00
|
|
|
| untracked | %u | Untracked files count (only when verbose mode enabled)
|
|
|
|
|
|
|
|
While `commit` and `position` are only available when in ['detached HEAD'
|
|
|
|
state](http://gitfaq.org/articles/what-is-a-detached-head.html), on the other
|
|
|
|
hand, `ahead`, `behind`, `diverged`, `branch` and `remote` are only available
|
|
|
|
when an actual branch is checked out (so when **not** in 'detached HEAD' state).
|
2016-12-02 22:49:45 +01:00
|
|
|
|
2018-12-17 20:11:16 +01:00
|
|
|
### Special action contexts
|
2016-12-02 22:49:45 +01:00
|
|
|
|
|
|
|
| Name | Format | Default Value
|
2018-12-22 04:48:54 +01:00
|
|
|
| --------------------------- | :-----: | --------------------------------------
|
2016-12-02 22:49:45 +01:00
|
|
|
| action:apply | value | 'apply'
|
|
|
|
| action:bisect | value | 'bisect'
|
|
|
|
| action:cherry-pick | value | 'cherry-pick'
|
|
|
|
| action:cherry-pick-sequence | value | 'cherry-pick-sequence'
|
|
|
|
| action:merge | value | 'merge'
|
|
|
|
| action:rebase | value | 'rebase'
|
|
|
|
| action:rebase-interactive | value | 'rebase-interactive'
|
|
|
|
| action:rebase-merge | value | 'rebase-merge'
|
|
|
|
|
|
|
|
Formatting example for special actions:
|
|
|
|
|
|
|
|
zstyle ':zim:git-info:action:bisect' format '<B>'
|
|
|
|
zstyle ':zim:git-info:action:merge' format '>M<'
|
|
|
|
zstyle ':zim:git-info:action:rebase' format '>R>'
|
|
|
|
|
|
|
|
### Usage
|
|
|
|
|
|
|
|
First, format the repository state attributes. For example, to format the
|
|
|
|
branch name, commit, and remote name, define the following styles:
|
|
|
|
|
|
|
|
zstyle ':zim:git-info:branch' format 'branch:%b'
|
|
|
|
zstyle ':zim:git-info:commit' format 'commit:%c'
|
|
|
|
zstyle ':zim:git-info:remote' format 'remote:%R'
|
|
|
|
|
|
|
|
Second, format how the above attributes are displayed in prompts:
|
|
|
|
|
|
|
|
zstyle ':zim:git-info:keys' format \
|
|
|
|
'prompt' 'git(%b%c)' \
|
|
|
|
'rprompt' '[%R]'
|
|
|
|
|
2018-12-22 04:48:54 +01:00
|
|
|
Last, add `${(e)git_info[prompt]}` and `${(e)git_info[rprompt]}` to `PS1` and
|
|
|
|
`RPS1` respectively, and call `git-info` in the `prompt_name_precmd` hook function.
|
2018-12-27 02:56:57 +01:00
|
|
|
|
|
|
|
Here's a complete example of a `prompt_example_setup` file:
|
|
|
|
```zsh
|
|
|
|
prompt_example_precmd() {
|
|
|
|
(( ${+functions[git-info]} )) && git-info
|
|
|
|
}
|
|
|
|
|
|
|
|
prompt_example_setup() {
|
|
|
|
autoload -Uz add-zsh-hook && add-zsh-hook precmd prompt_example_precmd
|
|
|
|
|
|
|
|
prompt_opts=(cr percent sp subst)
|
|
|
|
|
|
|
|
zstyle ':zim:git-info:branch' format 'branch:%b'
|
|
|
|
zstyle ':zim:git-info:commit' format 'commit:%c'
|
|
|
|
zstyle ':zim:git-info:remote' format 'remote:%R'
|
|
|
|
|
|
|
|
zstyle ':zim:git-info:keys' format \
|
|
|
|
'prompt' 'git(%b%c)' \
|
|
|
|
'rprompt' '[%R]'
|
|
|
|
|
|
|
|
PS1='${(e)git_info[prompt]}%# '
|
|
|
|
RPS1='${(e)git_info[rprompt]}'
|
|
|
|
}
|
|
|
|
|
|
|
|
prompt_example_setup "${@}"
|
|
|
|
```
|