summaryrefslogtreecommitdiffstats
path: root/README.md
diff options
context:
space:
mode:
authorClaudio Bandera <claudio.bandera@kit.edu>2015-10-16 16:49:10 +0200
committerClaudio Bandera <claudio.bandera@kit.edu>2015-10-16 16:49:10 +0200
commit5fd8e9dbdb540e8418bae51b882c7fd90458c13b (patch)
tree2b8ce9697b269eef1fb3490f95b67947facc27f5 /README.md
parenta7f6b47969e9c734ff28f5b49fdbbee6a6095b93 (diff)
parentf043242a00cc9a178ffa8205462c9cd61ffe36b2 (diff)
downloadgit-sonar-5fd8e9dbdb540e8418bae51b882c7fd90458c13b.tar.gz
git-sonar-5fd8e9dbdb540e8418bae51b882c7fd90458c13b.zip
Merge remote-tracking branch 'upstream/master' into hotfix/unittests
Diffstat (limited to 'README.md')
-rw-r--r--README.md69
1 files changed, 56 insertions, 13 deletions
diff --git a/README.md b/README.md
index 1538681..7686edb 100644
--- a/README.md
+++ b/README.md
@@ -17,6 +17,7 @@ last few years. Maybe it can help you too.
- [Local commits status](#local-commits-status)
- [Remote commits status](#remote-commits-status)
- [(Optional) Auto-fetch repos](#optional-auto-fetch-repos)
+- [Customise your prompt](#customise-your-prompt)
- [Support](#support)
- [Ensuring prompt execution](#ensuring-prompt-execution)
- [Configuring colours](#configuring-colours)
@@ -76,7 +77,7 @@ Add to your `config.fish`
function fish_prompt
set_color $fish_color_cwd
echo -n (prompt_pwd)
- git-radar --fish -fetch
+ git-radar --fish --fetch
set_color normal
echo -n ' > '
end
@@ -120,6 +121,9 @@ Red | Unstaged, you'll need to `git add` them before you can commit
Grey | Untracked, these are new files git is unaware of
Yellow | Conflicted, these need resolved before they can be committed
+The use of feature is controlled by the `GIT_RADAR_FORMAT` environment variable.
+See [Customise your prompt](#customise-your-prompt) for how to personalise this.
+
### Local commits status
The prompt will show you the difference in commits between your branch and the
@@ -132,6 +136,9 @@ Prompt | Meaning
![git:(master 3↓)] | We have 3 commits to pull down
![git:(master 3⇵5)] | Our version and origins version of `master` have diverged
+The use of feature is controlled by the `GIT_RADAR_FORMAT` environment variable.
+See [Customise your prompt](#customise-your-prompt) for how to personalise this.
+
### Remote commits status
The prompt will also show the difference between your branch on origin and what
@@ -146,19 +153,11 @@ Prompt | Meaning
![git:(m 4 → my-branch)] | There are 4 commits on `origin/master` that aren't on `origin/my-branch`
![git:(m 1 ⇄ 2 my-branch)] | `origin/master` and `origin/my-branch` have diverged, we'll need to rebase or merge
-If you don't rely on this status, you can always hide this part of the prompt by calling git-radar with `--no-remote-status`.
-
-**Bash**
-```bash
-export PS1="$PS1\$(git-radar --bash --fetch --no-remote-status) "
-```
-[(note: the `\` escaping the `$` is important)](#ensuring-prompt-execution)
+The use of feature is controlled by the `GIT_RADAR_FORMAT` environment variable.
+See [Customise your prompt](#customise-your-prompt) for how to personalise this.
-**Zsh**
-```zsh
-export PROMPT="$PROMPT\$(git-radar --zsh --fetch --no-remote-status) "
-```
-[(note: the `\` escaping the `$` is important)](#ensuring-prompt-execution)
+If you don't rely on this status, you can always hide this part of the prompt by
+[customising your prompt](#customise-your-prompt)
### (Optional) Auto-fetch repos
@@ -183,6 +182,50 @@ export PROMPT="$PROMPT\$(git-radar --zsh --fetch) "
```
[(note: the `\` escaping the `$` is important)](#ensuring-prompt-execution)
+## Customise your prompt
+
+Git Radar is highly customisable using a prompt format string. The 4 features
+above: remote commits, local commits, branch and file changes; are controlled
+by the prompt format string.
+
+Feature | Control string
+---------------|---------------
+Remote commits | `%{remote}`
+Local commits | `%{local}`
+Branch | `%{branch}`
+File changes | `%{changes}`
+
+You can create any prompt shape you prefer by exporting `GIT_RADAR_FORMAT` with
+your preferred shape. The control strings above will be replaced with the output
+of the corresponding feature.
+
+**Examples**
+
+GIT_RADAR_FORMAT | Result
+--------------------------------------|---------------------
+`%{branch}%{local}%{changes}` | `master1↑1M`
+`[%{branch}] - %{local} - %{changes}` | `[master] - 1↑ - 1M`
+
+### Prefixing and Suffixing the features
+
+Often you will want certain parts of the prompt to only appear when there is
+content to render. For example, when in a repo you want `[branch]` but when out
+of a repo you don't want the `[]` appearing.
+
+To do this the control strings support prefixes and suffixes. Prefixes and
+Suffixes are separated from the feature name by `:` and will only render if the
+feature would render:
+
+Format: `prompt > %{prefix - :changes: - suffix}`
+
+In a repo: `prompt > prefix - 1M - suffix`
+
+Outside a repo: `prompt > `
+
+The default prompt format uses this to add spaces only if the feature would
+render. In that way the prompt always looks well spaced out no matter how many
+features are rendering.
+
## Support
### Ensuring prompt execution