diff options
| author | Michael Allen <michael@michaelallen.io> | 2015-10-15 12:21:17 +0100 | 
|---|---|---|
| committer | Michael Allen <michael@michaelallen.io> | 2015-10-15 12:21:17 +0100 | 
| commit | 01149058a6df992547195b4147551ad7a64baf3c (patch) | |
| tree | 462d90a1f890135e770e2359f15f85cb63af7352 | |
| parent | 74fb6b46bb581813efb4d55a5b770ba3ca0218f5 (diff) | |
| download | git-sonar-01149058a6df992547195b4147551ad7a64baf3c.tar.gz git-sonar-01149058a6df992547195b4147551ad7a64baf3c.zip | |
Some readme to show how to use the format string
Diffstat (limited to '')
| -rw-r--r-- | README.md | 67 | 
1 files changed, 55 insertions, 12 deletions
| @@ -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) @@ -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 | 
