abra zsh config 2.0
This commit is contained in:
112
.zprezto/modules/prompt/external/pure/readme.md
vendored
112
.zprezto/modules/prompt/external/pure/readme.md
vendored
@@ -2,7 +2,7 @@
|
||||
|
||||
> Pretty, minimal and fast ZSH prompt
|
||||
|
||||

|
||||
<img src="screenshot.png" width="864">
|
||||
|
||||
|
||||
## Overview
|
||||
@@ -11,10 +11,10 @@ Most prompts are cluttered, ugly and slow. I wanted something visually pleasing
|
||||
|
||||
### Why?
|
||||
|
||||
- Comes with the perfect prompt character.
|
||||
- Comes with the perfect prompt character.
|
||||
Author went through the whole Unicode range to find it.
|
||||
- Shows `git` branch and whether it's dirty (with a `*`).
|
||||
- Indicates when you have unpushed/unpulled `git` commits with up/down arrows.
|
||||
- Indicates when you have unpushed/unpulled `git` commits with up/down arrows. *(Check is done asynchronously!)*
|
||||
- Prompt character turns red if the last command didn't exit with `0`.
|
||||
- Command execution time will be displayed if it exceeds the set threshold.
|
||||
- Username and host only displayed when in an SSH session.
|
||||
@@ -24,11 +24,11 @@ Most prompts are cluttered, ugly and slow. I wanted something visually pleasing
|
||||
|
||||
## Install
|
||||
|
||||
Can be installed with `npm` or manually. Requires git 2.0.0+ and ZSH 5.0.0+.
|
||||
Can be installed with `npm` or manually. Requires Git 2.0.0+ and ZSH 5.2+. Older versions of ZSH are known to work, but they are **not** recommended.
|
||||
|
||||
### npm
|
||||
|
||||
```
|
||||
```console
|
||||
$ npm install --global pure-prompt
|
||||
```
|
||||
|
||||
@@ -39,7 +39,7 @@ That's it. Skip to [Getting started](#getting-started).
|
||||
1. Either…
|
||||
- Clone this repo
|
||||
- add it as a submodule, or
|
||||
- just download `pure.zsh`
|
||||
- just download [`pure.zsh`](pure.zsh) and [`async.zsh`](async.zsh)
|
||||
|
||||
2. Symlink `pure.zsh` to somewhere in [`$fpath`](http://www.refining-linux.org/archives/46/ZSH-Gem-12-Autoloading-functions/) with the name `prompt_pure_setup`.
|
||||
|
||||
@@ -47,7 +47,7 @@ That's it. Skip to [Getting started](#getting-started).
|
||||
|
||||
#### Example
|
||||
|
||||
```
|
||||
```console
|
||||
$ ln -s "$PWD/pure.zsh" /usr/local/share/zsh/site-functions/prompt_pure_setup
|
||||
$ ln -s "$PWD/async.zsh" /usr/local/share/zsh/site-functions/async
|
||||
```
|
||||
@@ -62,7 +62,7 @@ fpath=( "$HOME/.zfunctions" $fpath )
|
||||
|
||||
Then install the theme there:
|
||||
|
||||
```sh
|
||||
```console
|
||||
$ ln -s "$PWD/pure.zsh" "$HOME/.zfunctions/prompt_pure_setup"
|
||||
$ ln -s "$PWD/async.zsh" "$HOME/.zfunctions/async"
|
||||
```
|
||||
@@ -74,7 +74,7 @@ Initialize the prompt system (if not so already) and choose `pure`:
|
||||
|
||||
```sh
|
||||
# .zshrc
|
||||
autoload -U promptinit && promptinit
|
||||
autoload -U promptinit; promptinit
|
||||
prompt pure
|
||||
```
|
||||
|
||||
@@ -95,7 +95,7 @@ Set `PURE_GIT_UNTRACKED_DIRTY=0` to not include untracked files in dirtiness che
|
||||
|
||||
### `PURE_GIT_DELAY_DIRTY_CHECK`
|
||||
|
||||
Time in seconds to delay git dirty checking for large repositories (git status takes > 2 seconds). The check is performed asynchronously, this is to save CPU. Defaults to `1800` seconds.
|
||||
Time in seconds to delay git dirty checking for large repositories (git status takes > 5 seconds). The check is performed asynchronously, this is to save CPU. Defaults to `1800` seconds.
|
||||
|
||||
### `PURE_PROMPT_SYMBOL`
|
||||
|
||||
@@ -114,7 +114,7 @@ Defines the git up arrow symbol. The default value is `⇡`.
|
||||
```sh
|
||||
# .zshrc
|
||||
|
||||
autoload -U promptinit && promptinit
|
||||
autoload -U promptinit; promptinit
|
||||
|
||||
# optionally define some options
|
||||
PURE_CMD_MAX_EXEC_TIME=10
|
||||
@@ -125,42 +125,74 @@ prompt pure
|
||||
|
||||
## Tips
|
||||
|
||||
[Tomorrow Night Eighties](https://github.com/chriskempson/tomorrow-theme) theme with the [Droid Sans Mono](http://www.google.com/webfonts/specimen/Droid+Sans+Mono) font (15pt) is a beautiful combination, as seen in the screenshot above. Just make sure you have anti-aliasing enabled in your Terminal.
|
||||
In the screenshot you see Pure running in [Hyper](https://hyper.is) with the [hyper-snazzy](https://github.com/sindresorhus/hyper-snazzy) theme and Menlo font.
|
||||
|
||||
To have commands colorized as seen in the screenshot install [zsh-syntax-highlighting](https://github.com/zsh-users/zsh-syntax-highlighting).
|
||||
The [Tomorrow Night Eighties](https://github.com/chriskempson/tomorrow-theme) theme with the [Droid Sans Mono](https://www.fontsquirrel.com/fonts/droid-sans-mono) font (15pt) is also a [nice combination](https://github.com/sindresorhus/pure/blob/95ee3e7618c6e2162a1e3cdac2a88a20ac3beb27/screenshot.png).<br>
|
||||
*Just make sure you have anti-aliasing enabled in your terminal.*
|
||||
|
||||
To have commands colorized as seen in the screenshot, install [zsh-syntax-highlighting](https://github.com/zsh-users/zsh-syntax-highlighting).
|
||||
|
||||
|
||||
## Integration
|
||||
|
||||
### [oh-my-zsh](https://github.com/robbyrussell/oh-my-zsh)
|
||||
|
||||
1. Remove competing theme included in oh-my-zsh `~/.oh-my-zsh/themes/pure.zsh-theme`
|
||||
2. Symlink (or copy) `pure.zsh` to `~/.oh-my-zsh/custom/pure.zsh-theme`
|
||||
3. Symlink (or copy) `async.zsh` to `~/.oh-my-zsh/custom/async.zsh`
|
||||
4. Add `ZSH_THEME="pure"` to your `.zshrc` file.
|
||||
1. Set `ZSH_THEME=""` in your `.zshrc` to disable oh-my-zsh themes.
|
||||
2. Follow the Pure [Install](#install) instructions.
|
||||
|
||||
**NOTE:** `oh-my-zsh` overrides the prompt so Pure must be activated *after* `source $ZSH/oh-my-zsh.sh`.
|
||||
|
||||
### [prezto](https://github.com/sorin-ionescu/prezto)
|
||||
|
||||
Set `zstyle ':prezto:module:prompt' theme 'pure'` in `~/.zpreztorc`.
|
||||
Pure is bundled with Prezto. No need to install it.
|
||||
|
||||
Add `prompt pure` to your `~/.zpreztorc`.
|
||||
|
||||
### [zim](https://github.com/Eriner/zim)
|
||||
|
||||
Pure is bundled with Zim. No need to install it.
|
||||
|
||||
Set `zprompt_theme='pure'` in `~/.zimrc`.
|
||||
|
||||
### [antigen](https://github.com/zsh-users/antigen)
|
||||
|
||||
Update your `.zshrc` file with the following two lines (order matters). Do not use the `antigen theme` function.
|
||||
|
||||
```
|
||||
```sh
|
||||
antigen bundle mafredri/zsh-async
|
||||
antigen bundle sindresorhus/pure
|
||||
```
|
||||
|
||||
### [antibody](https://github.com/getantibody/antibody)
|
||||
|
||||
Update your `.zshrc` file with the following two lines (order matters):
|
||||
|
||||
```sh
|
||||
antibody bundle mafredri/zsh-async
|
||||
antibody bundle sindresorhus/pure
|
||||
```
|
||||
|
||||
### [zplug](https://github.com/zplug/zplug)
|
||||
|
||||
Update your `.zshrc` file with the following two lines:
|
||||
|
||||
```sh
|
||||
zplug mafredri/zsh-async, from:github
|
||||
zplug sindresorhus/pure, use:pure.zsh, from:github, as:theme
|
||||
```
|
||||
|
||||
### [zplugin](https://github.com/zdharma/zplugin)
|
||||
|
||||
Update your `.zshrc` file with the following two lines (order matters):
|
||||
|
||||
```sh
|
||||
zplugin ice pick"async.zsh" src"pure.zsh"
|
||||
zplugin light sindresorhus/pure
|
||||
```
|
||||
|
||||
## FAQ
|
||||
|
||||
### My preprompt is missing when I clear the screen with Ctrl+L
|
||||
|
||||
Pure doesn't register its custom *clear-screen* widget if it has been previously modified. If you haven't registered your own zle widget with `zle -N clear-screen custom-clear-screen` it might have been done by third-party modules. For example `zsh-syntax-highlighting` and `zsh-history-substring-search` are known to do this and they should for that reason be **the very last thing** in your `.zshrc` (as pointed out in their documentation).
|
||||
|
||||
To find out the culprit that is overriding your *clear-screen* widget, you can run the following command: `zle -l | grep clear-screen`.
|
||||
|
||||
### I am stuck in a shell loop in my terminal that ask me to authenticate. What should I do ?
|
||||
### I am stuck in a shell loop in my terminal that asks me to authenticate. What should I do?
|
||||
|
||||
[This is a known issue](https://github.com/sindresorhus/pure/issues/76).
|
||||
Using `git pull` when you get the username prompt should help you to break the loop by giving you a real prompt for this. **[This has been fixed in git 2.3](https://github.com/sindresorhus/pure/commit/f43ab97e1cf4a276b7a6e33eac055ee16610be15)**
|
||||
@@ -171,22 +203,38 @@ Using `git pull` when you get the username prompt should help you to break the l
|
||||
|
||||
#### Gentoo
|
||||
|
||||
```
|
||||
sudo sh -c "echo 'SANDBOX_WRITE=\"/dev/ptmx\"' > /etc/sandbox.d/10zsh"
|
||||
sudo emerge -1 zsh
|
||||
```console
|
||||
$ sudo sh -c "echo 'SANDBOX_WRITE=\"/dev/ptmx\"' > /etc/sandbox.d/10zsh"
|
||||
$ sudo emerge -1 zsh
|
||||
```
|
||||
|
||||
#### FreeBSD 10.1
|
||||
|
||||
On a default setup, running the command `kldload pty` should do the trick. If you have a custom kernel, you might need to add `device pty` to the configuration file ([example](https://github.com/nbari/freebsd/blob/58646a9c3c4aaabf6f6467ff505f27f09e29dc75/kernels/xen.kernel#L188)).
|
||||
|
||||
|
||||
## Ports
|
||||
|
||||
- **ZSH**
|
||||
- [therealklanni/purity](https://github.com/therealklanni/purity) - More compact current working directory, important details on the main prompt line, and extra Git indicators.
|
||||
- [intelfx/pure](https://github.com/intelfx/pure) - Solarized-friendly colors, highly verbose, and fully async Git integration.
|
||||
- [dfurnes/purer](https://github.com/dfurnes/purer) - Compact single-line prompt with built-in Vim-mode indicator.
|
||||
- **Bash**
|
||||
- [sapegin/dotfiles](https://github.com/sapegin/dotfiles) - [Prompt](https://github.com/sapegin/dotfiles/blob/dd063f9c30de7d2234e8accdb5272a5cc0a3388b/includes/bash_prompt.bash) and [color theme](https://github.com/sapegin/dotfiles/tree/master/color) for Terminal.app.
|
||||
- **Fish**
|
||||
- [brandonweiss/pure.fish](https://github.com/brandonweiss/pure.fish) - Pure-inspired prompt for Fish. Not intended to have feature parity.
|
||||
- [rafaelrinaldi/pure](https://github.com/rafaelrinaldi/pure) - Support for bare Fish and various framework ([Oh-My-Fish](https://github.com//oh-my-fish/oh-my-fish), [Fisherman](https://github.com//fisherman/fisherman), and [Wahoo](https://github.com//bucaran/wahoo)).
|
||||
- **Rust**
|
||||
- [xcambar/purs](https://github.com/xcambar/purs) - Pure-inspired prompt in Rust.
|
||||
|
||||
|
||||
## Team
|
||||
|
||||
[](http://sindresorhus.com) | [](https://github.com/mafredri)
|
||||
[](http://sindresorhus.com) | [](https://github.com/mafredri)
|
||||
---|---
|
||||
[Sindre Sorhus](http://sindresorhus.com) | [Mathias Fredriksson](https://github.com/mafredri)
|
||||
[Sindre Sorhus](https://github.com/sindresorhus) | [Mathias Fredriksson](https://github.com/mafredri)
|
||||
|
||||
|
||||
## License
|
||||
|
||||
MIT © [Sindre Sorhus](http://sindresorhus.com)
|
||||
MIT © [Sindre Sorhus](https://sindresorhus.com)
|
||||
|
Reference in New Issue
Block a user