From caa9323eae8ec54afd6158472ee71050ea584842 Mon Sep 17 00:00:00 2001 From: Hsieh Chin Fan Date: Fri, 18 Nov 2022 13:05:06 +0800 Subject: Add custom zshrc --- zsh/ps1 | 133 ---------------------------------------------------------------- 1 file changed, 133 deletions(-) delete mode 100644 zsh/ps1 (limited to 'zsh/ps1') diff --git a/zsh/ps1 b/zsh/ps1 deleted file mode 100644 index 903bc79..0000000 --- a/zsh/ps1 +++ /dev/null @@ -1,133 +0,0 @@ -# Purification -# by Matthieu Cneude -# https://github.com/Phantas0s/purification - -# Based on: - -# Purity -# by Kevin Lanni -# https://github.com/therealklanni/purity -# MIT License - -# prompt: -# %F => color dict -# %f => reset color -# %~ => current path -# %* => time -# %n => username -# %m => shortname host -# %(?..) => prompt conditional - %(condition.true.false) - -# Display git status -# TODO to refactor with switch / using someting else than grep -# Might be faster using ripgrep too -git_prompt_status() { - local INDEX STATUS - - INDEX=$(command git status --porcelain -b 2> /dev/null) - - STATUS="" - - if $(echo "$INDEX" | command grep -E '^\?\? ' &> /dev/null); then - STATUS="$ZSH_THEME_GIT_PROMPT_UNTRACKED$STATUS" - fi - - if $(echo "$INDEX" | grep '^A ' &> /dev/null); then - STATUS="$ZSH_THEME_GIT_PROMPT_ADDED$STATUS" - elif $(echo "$INDEX" | grep '^M ' &> /dev/null); then - STATUS="$ZSH_THEME_GIT_PROMPT_ADDED$STATUS" - elif $(echo "$INDEX" | grep '^MM ' &> /dev/null); then - STATUS="$ZSH_THEME_GIT_PROMPT_ADDED$STATUS" - fi - - if $(echo "$INDEX" | grep '^ M ' &> /dev/null); then - STATUS="$ZSH_THEME_GIT_PROMPT_MODIFIED$STATUS" - elif $(echo "$INDEX" | grep '^AM ' &> /dev/null); then - STATUS="$ZSH_THEME_GIT_PROMPT_MODIFIED$STATUS" - elif $(echo "$INDEX" | grep '^MM ' &> /dev/null); then - STATUS="$ZSH_THEME_GIT_PROMPT_MODIFIED$STATUS" - elif $(echo "$INDEX" | grep '^ T ' &> /dev/null); then - STATUS="$ZSH_THEME_GIT_PROMPT_MODIFIED$STATUS" - fi - - if $(echo "$INDEX" | grep '^R ' &> /dev/null); then - STATUS="$ZSH_THEME_GIT_PROMPT_RENAMED$STATUS" - fi - - if $(echo "$INDEX" | grep '^ D ' &> /dev/null); then - STATUS="$ZSH_THEME_GIT_PROMPT_DELETED$STATUS" - elif $(echo "$INDEX" | grep '^D ' &> /dev/null); then - STATUS="$ZSH_THEME_GIT_PROMPT_DELETED$STATUS" - elif $(echo "$INDEX" | grep '^AD ' &> /dev/null); then - STATUS="$ZSH_THEME_GIT_PROMPT_DELETED$STATUS" - fi - - if $(command git rev-parse --verify refs/stash >/dev/null 2>&1); then - STATUS="$ZSH_THEME_GIT_PROMPT_STASHED$STATUS" - fi - - if $(echo "$INDEX" | grep '^UU ' &> /dev/null); then - STATUS="$ZSH_THEME_GIT_PROMPT_UNMERGED$STATUS" - fi - - if $(echo "$INDEX" | grep '^## [^ ]\+ .*ahead' &> /dev/null); then - STATUS="$ZSH_THEME_GIT_PROMPT_AHEAD$STATUS" - fi - - if $(echo "$INDEX" | grep '^## [^ ]\+ .*behind' &> /dev/null); then - STATUS="$ZSH_THEME_GIT_PROMPT_BEHIND$STATUS" - fi - - if $(echo "$INDEX" | grep '^## [^ ]\+ .*diverged' &> /dev/null); then - STATUS="$ZSH_THEME_GIT_PROMPT_DIVERGED$STATUS" - fi - - if [[ ! -z "$STATUS" ]]; then - echo " [ $STATUS]" - fi -} - - -prompt_git_branch() { - autoload -Uz vcs_info - precmd_vcs_info() { vcs_info } - precmd_functions+=( precmd_vcs_info ) - setopt prompt_subst - zstyle ':vcs_info:git:*' formats '%b' -} - -prompt_git_info() { - [ ! -z "$vcs_info_msg_0_" ] && echo "$ZSH_THEME_GIT_PROMPT_PREFIX%F{white}$vcs_info_msg_0_%f$ZSH_THEME_GIT_PROMPT_SUFFIX" -} - -prompt_purity_precmd() { - # Pass a line before each prompt - print -P '' -} - -prompt_purification_setup() { - # Display git branch - - autoload -Uz add-zsh-hook - add-zsh-hook precmd prompt_purity_precmd - - ZSH_THEME_GIT_PROMPT_PREFIX=" %F{red}λ%f:" - ZSH_THEME_GIT_PROMPT_DIRTY="" - ZSH_THEME_GIT_PROMPT_CLEAN="" - - ZSH_THEME_GIT_PROMPT_ADDED="%F{green}+%f " - ZSH_THEME_GIT_PROMPT_MODIFIED="%F{blue}%f " - ZSH_THEME_GIT_PROMPT_DELETED="%F{red}x%f " - ZSH_THEME_GIT_PROMPT_RENAMED="%F{magenta}➜%f " - ZSH_THEME_GIT_PROMPT_UNMERGED="%F{yellow}═%f " - ZSH_THEME_GIT_PROMPT_UNTRACKED="%F{white}%f " - ZSH_THEME_GIT_PROMPT_STASHED="%B%F{red}%f%b " - ZSH_THEME_GIT_PROMPT_BEHIND="%B%F{red}%f%b " - ZSH_THEME_GIT_PROMPT_AHEAD="%B%F{green}%f%b " - - prompt_git_branch - RPROMPT='$(prompt_git_info) $(git_prompt_status)' - PROMPT=$'%F{white}%~ %B%F{blue}>%f%b ' -} - -prompt_purification_setup -- cgit v1.2.3-70-g09d2