Skip to content

Pretty, minimal and fast ZSH prompt with right prompt time

License

Notifications You must be signed in to change notification settings

depressiveRobot/pure-time

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

pure-time

Pretty, minimal and fast ZSH prompt based on Pure

  • Comes with the prompt character.
  • Shows git branch and whether it's dirty (with a ×).
  • Indicates when you have unpushed/unpulled git commits with up/down triangles. (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.
  • Shows the current path in the title and the current folder & command when a process is running.
  • Shows the current time on the right side of the prompt.

Install

Update your .zshrc file with the following two lines (order matters):

$ zgen load mafredri/zsh-async
$ zgen load depressiveRobot/pure-time
  1. Symlink (or copy) pure-time.zsh to ~/.oh-my-zsh/custom/themes/pure-time.zsh-theme.
  2. Set ZSH_THEME="pure-time" in your .zshrc file.

Update your .zshrc file with the following two lines (order matters). Do not use the antigen theme function.

$ antigen bundle mafredri/zsh-async
$ antigen bundle depressiveRobot/pure-time

Update your .zshrc file with the following two lines (order matters):

$ antibody bundle mafredri/zsh-async
$ antibody bundle depressiveRobot/pure-time

Manually

  1. Either…
  • Clone this repo
  • add it as a submodule, or
  • just download pure-time.zsh and async.zsh
  1. Symlink pure-time.zsh to somewhere in $fpath with the name prompt_pure-time_setup.

  2. Symlink async.zsh in $fpath with the name async.

Example

$ ln -s "$PWD/pure-time.zsh" /usr/local/share/zsh/site-functions/prompt_pure-time_setup
$ ln -s "$PWD/async.zsh" /usr/local/share/zsh/site-functions/async

Run echo $fpath to see possible locations.

For a user-specific installation (which would not require escalated privileges), simply add a directory to $fpath for that user:

# .zshenv or .zshrc
fpath=( "$HOME/.zfunctions" $fpath )

Then install the theme there:

$ ln -s "$PWD/pure-time.zsh" "$HOME/.zfunctions/prompt_pure-time_setup"
$ ln -s "$PWD/async.zsh" "$HOME/.zfunctions/async"

Getting started

Initialize the prompt system (if not so already) and choose pure-time:

# .zshrc
autoload -U promptinit; promptinit
prompt pure-time

Options

PURE_CMD_MAX_EXEC_TIME

The max execution time of a process before its run time is shown when it exits. Defaults to 5 seconds.

PURE_GIT_PULL

Set PURE_GIT_PULL=0 to prevent Pure from checking whether the current Git remote has been updated.

PURE_GIT_UNTRACKED_DIRTY

Set PURE_GIT_UNTRACKED_DIRTY=0 to not include untracked files in dirtiness check. Only really useful on extremely huge repos like the WebKit repo.

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.

PURE_PROMPT_SYMBOL

Defines the prompt symbol. The default value is .

PURE_GIT_DOWN_ARROW

Defines the git down arrow symbol. The default value is .

PURE_GIT_UP_ARROW

Defines the git up arrow symbol. The default value is .

PURE_GIT_DIRTY

Defines the git dirty symbol. The default value is ×.

Example

# .zshrc

autoload -U promptinit; promptinit

# optionally define some options
PURE_CMD_MAX_EXEC_TIME=10

prompt pure-time

License

MIT © depressiveRobot based on λ Pure by Michał Nykiel

About

Pretty, minimal and fast ZSH prompt with right prompt time

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • Shell 100.0%