commit
efed909db2
6 changed files with 522 additions and 0 deletions
@ -0,0 +1,218 @@ |
|||||||
|
# Outputs current branch info in prompt format |
||||||
|
function git_prompt_info() { |
||||||
|
local ref |
||||||
|
if [[ "$(command git config --get oh-my-zsh.hide-status 2>/dev/null)" != "1" ]]; then |
||||||
|
ref=$(command git symbolic-ref HEAD 2> /dev/null) || \ |
||||||
|
ref=$(command git rev-parse --short HEAD 2> /dev/null) || return 0 |
||||||
|
echo "$ZSH_THEME_GIT_PROMPT_PREFIX${ref#refs/heads/}$(parse_git_dirty)$ZSH_THEME_GIT_PROMPT_SUFFIX" |
||||||
|
fi |
||||||
|
} |
||||||
|
|
||||||
|
# Checks if working tree is dirty |
||||||
|
function parse_git_dirty() { |
||||||
|
local STATUS='' |
||||||
|
local FLAGS |
||||||
|
FLAGS=('--porcelain') |
||||||
|
if [[ "$(command git config --get oh-my-zsh.hide-dirty)" != "1" ]]; then |
||||||
|
if [[ $POST_1_7_2_GIT -gt 0 ]]; then |
||||||
|
FLAGS+='--ignore-submodules=dirty' |
||||||
|
fi |
||||||
|
if [[ "$DISABLE_UNTRACKED_FILES_DIRTY" == "true" ]]; then |
||||||
|
FLAGS+='--untracked-files=no' |
||||||
|
fi |
||||||
|
STATUS=$(command git status ${FLAGS} 2> /dev/null | tail -n1) |
||||||
|
fi |
||||||
|
if [[ -n $STATUS ]]; then |
||||||
|
echo "$ZSH_THEME_GIT_PROMPT_DIRTY" |
||||||
|
else |
||||||
|
echo "$ZSH_THEME_GIT_PROMPT_CLEAN" |
||||||
|
fi |
||||||
|
} |
||||||
|
|
||||||
|
# Gets the difference between the local and remote branches |
||||||
|
function git_remote_status() { |
||||||
|
local remote ahead behind git_remote_status git_remote_status_detailed |
||||||
|
remote=${$(command git rev-parse --verify ${hook_com[branch]}@{upstream} --symbolic-full-name 2>/dev/null)/refs\/remotes\/} |
||||||
|
if [[ -n ${remote} ]]; then |
||||||
|
ahead=$(command git rev-list ${hook_com[branch]}@{upstream}..HEAD 2>/dev/null | wc -l) |
||||||
|
behind=$(command git rev-list HEAD..${hook_com[branch]}@{upstream} 2>/dev/null | wc -l) |
||||||
|
|
||||||
|
if [[ $ahead -eq 0 ]] && [[ $behind -eq 0 ]]; then |
||||||
|
git_remote_status="$ZSH_THEME_GIT_PROMPT_EQUAL_REMOTE" |
||||||
|
elif [[ $ahead -gt 0 ]] && [[ $behind -eq 0 ]]; then |
||||||
|
git_remote_status="$ZSH_THEME_GIT_PROMPT_AHEAD_REMOTE" |
||||||
|
git_remote_status_detailed="$ZSH_THEME_GIT_PROMPT_AHEAD_REMOTE_COLOR$ZSH_THEME_GIT_PROMPT_AHEAD_REMOTE$((ahead))%{$reset_color%}" |
||||||
|
elif [[ $behind -gt 0 ]] && [[ $ahead -eq 0 ]]; then |
||||||
|
git_remote_status="$ZSH_THEME_GIT_PROMPT_BEHIND_REMOTE" |
||||||
|
git_remote_status_detailed="$ZSH_THEME_GIT_PROMPT_BEHIND_REMOTE_COLOR$ZSH_THEME_GIT_PROMPT_BEHIND_REMOTE$((behind))%{$reset_color%}" |
||||||
|
elif [[ $ahead -gt 0 ]] && [[ $behind -gt 0 ]]; then |
||||||
|
git_remote_status="$ZSH_THEME_GIT_PROMPT_DIVERGED_REMOTE" |
||||||
|
git_remote_status_detailed="$ZSH_THEME_GIT_PROMPT_AHEAD_REMOTE_COLOR$ZSH_THEME_GIT_PROMPT_AHEAD_REMOTE$((ahead))%{$reset_color%}$ZSH_THEME_GIT_PROMPT_BEHIND_REMOTE_COLOR$ZSH_THEME_GIT_PROMPT_BEHIND_REMOTE$((behind))%{$reset_color%}" |
||||||
|
fi |
||||||
|
|
||||||
|
if [[ -n $ZSH_THEME_GIT_PROMPT_REMOTE_STATUS_DETAILED ]]; then |
||||||
|
git_remote_status="$ZSH_THEME_GIT_PROMPT_REMOTE_STATUS_PREFIX$remote$git_remote_status_detailed$ZSH_THEME_GIT_PROMPT_REMOTE_STATUS_SUFFIX" |
||||||
|
fi |
||||||
|
|
||||||
|
echo $git_remote_status |
||||||
|
fi |
||||||
|
} |
||||||
|
|
||||||
|
# Outputs the name of the current branch |
||||||
|
# Usage example: git pull origin $(git_current_branch) |
||||||
|
# Using '--quiet' with 'symbolic-ref' will not cause a fatal error (128) if |
||||||
|
# it's not a symbolic ref, but in a Git repo. |
||||||
|
function git_current_branch() { |
||||||
|
local ref |
||||||
|
ref=$(command git symbolic-ref --quiet HEAD 2> /dev/null) |
||||||
|
local ret=$? |
||||||
|
if [[ $ret != 0 ]]; then |
||||||
|
[[ $ret == 128 ]] && return # no git repo. |
||||||
|
ref=$(command git rev-parse --short HEAD 2> /dev/null) || return |
||||||
|
fi |
||||||
|
echo ${ref#refs/heads/} |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
# Gets the number of commits ahead from remote |
||||||
|
function git_commits_ahead() { |
||||||
|
if command git rev-parse --git-dir &>/dev/null; then |
||||||
|
local commits="$(git rev-list --count @{upstream}..HEAD)" |
||||||
|
if [[ "$commits" != 0 ]]; then |
||||||
|
echo "$ZSH_THEME_GIT_COMMITS_AHEAD_PREFIX$commits$ZSH_THEME_GIT_COMMITS_AHEAD_SUFFIX" |
||||||
|
fi |
||||||
|
fi |
||||||
|
} |
||||||
|
|
||||||
|
# Gets the number of commits behind remote |
||||||
|
function git_commits_behind() { |
||||||
|
if command git rev-parse --git-dir &>/dev/null; then |
||||||
|
local commits="$(git rev-list --count HEAD..@{upstream})" |
||||||
|
if [[ "$commits" != 0 ]]; then |
||||||
|
echo "$ZSH_THEME_GIT_COMMITS_BEHIND_PREFIX$commits$ZSH_THEME_GIT_COMMITS_BEHIND_SUFFIX" |
||||||
|
fi |
||||||
|
fi |
||||||
|
} |
||||||
|
|
||||||
|
# Outputs if current branch is ahead of remote |
||||||
|
function git_prompt_ahead() { |
||||||
|
if [[ -n "$(command git rev-list origin/$(git_current_branch)..HEAD 2> /dev/null)" ]]; then |
||||||
|
echo "$ZSH_THEME_GIT_PROMPT_AHEAD" |
||||||
|
fi |
||||||
|
} |
||||||
|
|
||||||
|
# Outputs if current branch is behind remote |
||||||
|
function git_prompt_behind() { |
||||||
|
if [[ -n "$(command git rev-list HEAD..origin/$(git_current_branch) 2> /dev/null)" ]]; then |
||||||
|
echo "$ZSH_THEME_GIT_PROMPT_BEHIND" |
||||||
|
fi |
||||||
|
} |
||||||
|
|
||||||
|
# Outputs if current branch exists on remote or not |
||||||
|
function git_prompt_remote() { |
||||||
|
if [[ -n "$(command git show-ref origin/$(git_current_branch) 2> /dev/null)" ]]; then |
||||||
|
echo "$ZSH_THEME_GIT_PROMPT_REMOTE_EXISTS" |
||||||
|
else |
||||||
|
echo "$ZSH_THEME_GIT_PROMPT_REMOTE_MISSING" |
||||||
|
fi |
||||||
|
} |
||||||
|
|
||||||
|
# Formats prompt string for current git commit short SHA |
||||||
|
function git_prompt_short_sha() { |
||||||
|
local SHA |
||||||
|
SHA=$(command git rev-parse --short HEAD 2> /dev/null) && echo "$ZSH_THEME_GIT_PROMPT_SHA_BEFORE$SHA$ZSH_THEME_GIT_PROMPT_SHA_AFTER" |
||||||
|
} |
||||||
|
|
||||||
|
# Formats prompt string for current git commit long SHA |
||||||
|
function git_prompt_long_sha() { |
||||||
|
local SHA |
||||||
|
SHA=$(command git rev-parse HEAD 2> /dev/null) && echo "$ZSH_THEME_GIT_PROMPT_SHA_BEFORE$SHA$ZSH_THEME_GIT_PROMPT_SHA_AFTER" |
||||||
|
} |
||||||
|
|
||||||
|
# Get the status of the working tree |
||||||
|
function 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" |
||||||
|
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 '^ 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 |
||||||
|
echo $STATUS |
||||||
|
} |
||||||
|
|
||||||
|
# Compares the provided version of git to the version installed and on path |
||||||
|
# Outputs -1, 0, or 1 if the installed version is less than, equal to, or |
||||||
|
# greater than the input version, respectively. |
||||||
|
function git_compare_version() { |
||||||
|
local INPUT_GIT_VERSION INSTALLED_GIT_VERSION |
||||||
|
INPUT_GIT_VERSION=(${(s/./)1}) |
||||||
|
INSTALLED_GIT_VERSION=($(command git --version 2>/dev/null)) |
||||||
|
INSTALLED_GIT_VERSION=(${(s/./)INSTALLED_GIT_VERSION[3]}) |
||||||
|
|
||||||
|
for i in {1..3}; do |
||||||
|
if [[ $INSTALLED_GIT_VERSION[$i] -gt $INPUT_GIT_VERSION[$i] ]]; then |
||||||
|
echo 1 |
||||||
|
return 0 |
||||||
|
fi |
||||||
|
if [[ $INSTALLED_GIT_VERSION[$i] -lt $INPUT_GIT_VERSION[$i] ]]; then |
||||||
|
echo -1 |
||||||
|
return 0 |
||||||
|
fi |
||||||
|
done |
||||||
|
echo 0 |
||||||
|
} |
||||||
|
|
||||||
|
# Outputs the name of the current user |
||||||
|
# Usage example: $(git_current_user_name) |
||||||
|
function git_current_user_name() { |
||||||
|
command git config user.name 2>/dev/null |
||||||
|
} |
||||||
|
|
||||||
|
# Outputs the email of the current user |
||||||
|
# Usage example: $(git_current_user_email) |
||||||
|
function git_current_user_email() { |
||||||
|
command git config user.email 2>/dev/null |
||||||
|
} |
||||||
|
|
||||||
|
# This is unlikely to change so make it all statically assigned |
||||||
|
POST_1_7_2_GIT=$(git_compare_version "1.7.2") |
||||||
|
# Clean up the namespace slightly by removing the checker function |
||||||
|
unfunction git_compare_version |
||||||
|
|
||||||
@ -0,0 +1,41 @@ |
|||||||
|
# create a zkbd compatible hash; |
||||||
|
# to add other keys to this hash, see: man 5 terminfo |
||||||
|
typeset -A key |
||||||
|
|
||||||
|
key[Home]=${terminfo[khome]} |
||||||
|
key[End]=${terminfo[kend]} |
||||||
|
key[Insert]=${terminfo[kich1]} |
||||||
|
key[Delete]=${terminfo[kdch1]} |
||||||
|
key[Up]=${terminfo[kcuu1]} |
||||||
|
key[Down]=${terminfo[kcud1]} |
||||||
|
key[Left]=${terminfo[kcub1]} |
||||||
|
key[Right]=${terminfo[kcuf1]} |
||||||
|
key[PageUp]=${terminfo[kpp]} |
||||||
|
key[PageDown]=${terminfo[knp]} |
||||||
|
|
||||||
|
# setup key accordingly |
||||||
|
[[ -n "${key[Home]}" ]] && bindkey "${key[Home]}" beginning-of-line |
||||||
|
[[ -n "${key[End]}" ]] && bindkey "${key[End]}" end-of-line |
||||||
|
[[ -n "${key[Insert]}" ]] && bindkey "${key[Insert]}" overwrite-mode |
||||||
|
[[ -n "${key[Delete]}" ]] && bindkey "${key[Delete]}" delete-char |
||||||
|
[[ -n "${key[Left]}" ]] && bindkey "${key[Left]}" backward-char |
||||||
|
[[ -n "${key[Right]}" ]] && bindkey "${key[Right]}" forward-char |
||||||
|
|
||||||
|
# prefix history search |
||||||
|
autoload -U history-search-end |
||||||
|
zle -N history-beginning-search-backward-end history-search-end |
||||||
|
bindkey "^[[A" history-beginning-search-backward |
||||||
|
bindkey "^[[B" history-beginning-search-forward |
||||||
|
|
||||||
|
# Finally, make sure the terminal is in application mode, when zle is |
||||||
|
# active. Only then are the values from $terminfo valid. |
||||||
|
if (( ${+terminfo[smkx]} )) && (( ${+terminfo[rmkx]} )); then |
||||||
|
function zle-line-init () { |
||||||
|
echoti smkx |
||||||
|
} |
||||||
|
function zle-line-finish () { |
||||||
|
echoti rmkx |
||||||
|
} |
||||||
|
zle -N zle-line-init |
||||||
|
zle -N zle-line-finish |
||||||
|
fi |
||||||
@ -0,0 +1,162 @@ |
|||||||
|
### |
||||||
|
# PROMPT LOOKS |
||||||
|
### |
||||||
|
|
||||||
|
functions rbenv_prompt_info >& /dev/null || rbenv_prompt_info(){} |
||||||
|
|
||||||
|
function theme_precmd { |
||||||
|
local TERMWIDTH |
||||||
|
(( TERMWIDTH = ${COLUMNS} - 1 )) |
||||||
|
|
||||||
|
|
||||||
|
### |
||||||
|
# Truncate the path if it's too long. |
||||||
|
|
||||||
|
PR_FILLBAR="" |
||||||
|
PR_PWDLEN="" |
||||||
|
|
||||||
|
local promptsize=${#${(%):---(%n@%m:%l)---()--}} |
||||||
|
local date=$(date +"%a--%b%d-----%H:%M:%S-") |
||||||
|
#local promptsize=${#date} |
||||||
|
local rubyprompt=`rbenv_prompt_info || rvm_prompt_info` |
||||||
|
local rubypromptsize=${#${rubyprompt}} |
||||||
|
#local pwdsize=${#${(%):-%~}} |
||||||
|
local pwdsize=${#date} |
||||||
|
|
||||||
|
if [[ "$promptsize + $rubypromptsize + $pwdsize" -gt $TERMWIDTH ]]; then |
||||||
|
((PR_PWDLEN=$TERMWIDTH - $promptsize)) |
||||||
|
else |
||||||
|
PR_FILLBAR="\${(l.(($TERMWIDTH - ($promptsize + $rubypromptsize + $pwdsize)))..${PR_HBAR}.)}" |
||||||
|
fi |
||||||
|
|
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
setopt extended_glob |
||||||
|
theme_preexec () { |
||||||
|
if [[ "$TERM" == "screen" ]]; then |
||||||
|
local CMD=${1[(wr)^(*=*|sudo|-*)]} |
||||||
|
echo -n "\ek$CMD\e\\" |
||||||
|
fi |
||||||
|
} |
||||||
|
|
||||||
|
|
||||||
|
setprompt () { |
||||||
|
### |
||||||
|
# Need this so the prompt will work. |
||||||
|
|
||||||
|
setopt prompt_subst |
||||||
|
|
||||||
|
|
||||||
|
### |
||||||
|
# See if we can use colors. |
||||||
|
|
||||||
|
autoload zsh/terminfo |
||||||
|
for color in RED GREEN YELLOW BLUE MAGENTA CYAN WHITE GREY; do |
||||||
|
eval PR_$color='%{$terminfo[bold]$fg[${(L)color}]%}' |
||||||
|
eval PR_LIGHT_$color='%{$fg[${(L)color}]%}' |
||||||
|
(( count = $count + 1 )) |
||||||
|
done |
||||||
|
PR_NO_COLOUR="%{$terminfo[sgr0]%}" |
||||||
|
|
||||||
|
### |
||||||
|
# Modify Git prompt |
||||||
|
ZSH_THEME_GIT_PROMPT_PREFIX=" on %{$fg[green]%}" |
||||||
|
ZSH_THEME_GIT_PROMPT_SUFFIX="%{$reset_color%}" |
||||||
|
ZSH_THEME_GIT_PROMPT_DIRTY="" |
||||||
|
ZSH_THEME_GIT_PROMPT_CLEAN="" |
||||||
|
|
||||||
|
ZSH_THEME_GIT_PROMPT_ADDED="%{$fg[green]%} ✚" |
||||||
|
ZSH_THEME_GIT_PROMPT_MODIFIED="%{$fg[blue]%} ✹" |
||||||
|
ZSH_THEME_GIT_PROMPT_DELETED="%{$fg[red]%} ✖" |
||||||
|
ZSH_THEME_GIT_PROMPT_RENAMED="%{$fg[magenta]%} ➜" |
||||||
|
ZSH_THEME_GIT_PROMPT_UNMERGED="%{$fg[yellow]%} ═" |
||||||
|
ZSH_THEME_GIT_PROMPT_UNTRACKED="%{$fg[cyan]%} ✭" |
||||||
|
|
||||||
|
### |
||||||
|
# See if we can use extended characters to look nicer. |
||||||
|
# UTF-8 Fixed |
||||||
|
|
||||||
|
if [[ $(locale charmap) == "UTF-8" ]]; then |
||||||
|
PR_SET_CHARSET="" |
||||||
|
PR_SHIFT_IN="" |
||||||
|
PR_SHIFT_OUT="" |
||||||
|
PR_HBAR="─" |
||||||
|
PR_ULCORNER="┌" |
||||||
|
PR_LLCORNER="└" |
||||||
|
PR_LRCORNER="┘" |
||||||
|
PR_URCORNER="┐" |
||||||
|
else |
||||||
|
typeset -A altchar |
||||||
|
set -A altchar ${(s..)terminfo[acsc]} |
||||||
|
# Some stuff to help us draw nice lines |
||||||
|
PR_SET_CHARSET="%{$terminfo[enacs]%}" |
||||||
|
PR_SHIFT_IN="%{$terminfo[smacs]%}" |
||||||
|
PR_SHIFT_OUT="%{$terminfo[rmacs]%}" |
||||||
|
PR_HBAR='$PR_SHIFT_IN${altchar[q]:--}$PR_SHIFT_OUT' |
||||||
|
PR_ULCORNER='$PR_SHIFT_IN${altchar[l]:--}$PR_SHIFT_OUT' |
||||||
|
PR_LLCORNER='$PR_SHIFT_IN${altchar[m]:--}$PR_SHIFT_OUT' |
||||||
|
PR_LRCORNER='$PR_SHIFT_IN${altchar[j]:--}$PR_SHIFT_OUT' |
||||||
|
PR_URCORNER='$PR_SHIFT_IN${altchar[k]:--}$PR_SHIFT_OUT' |
||||||
|
fi |
||||||
|
|
||||||
|
|
||||||
|
### |
||||||
|
# Decide if we need to set titlebar text. |
||||||
|
|
||||||
|
case $TERM in |
||||||
|
xterm*) |
||||||
|
PR_TITLEBAR=$'%{\e]0;%(!.-=*[ROOT]*=- | .)%n@%m:%~ | ${COLUMNS}x${LINES} | %y\a%}' |
||||||
|
;; |
||||||
|
screen) |
||||||
|
PR_TITLEBAR=$'%{\e_screen \005 (\005t) | %(!.-=[ROOT]=- | .)%n@%m:%~ | ${COLUMNS}x${LINES} | %y\e\\%}' |
||||||
|
;; |
||||||
|
*) |
||||||
|
PR_TITLEBAR='' |
||||||
|
;; |
||||||
|
esac |
||||||
|
|
||||||
|
|
||||||
|
### |
||||||
|
# Decide whether to set a screen title |
||||||
|
if [[ "$TERM" == "screen" ]]; then |
||||||
|
PR_STITLE=$'%{\ekzsh\e\\%}' |
||||||
|
else |
||||||
|
PR_STITLE='' |
||||||
|
fi |
||||||
|
|
||||||
|
|
||||||
|
### |
||||||
|
# Finally, the prompt. |
||||||
|
|
||||||
|
PROMPT='$PR_SET_CHARSET$PR_STITLE${(e)PR_TITLEBAR}\ |
||||||
|
$PR_GREY$PR_ULCORNER$PR_HBAR$PR_WHITE(\ |
||||||
|
$PR_CYAN%(!.%SROOT%s.%n)$PR_WHITE@$PR_GREEN%m:%l\ |
||||||
|
$PR_WHITE)`rbenv_prompt_info || rvm_prompt_info`$PR_GREY$PR_HBAR$PR_HBAR${(e)PR_FILLBAR}$PR_HBAR$PR_WHITE(\ |
||||||
|
$PR_YELLOW%D{%a, %b%d}$PR_WHITE)$PR_GREY$PR_HBAR$PR_HBAR$PR_HBAR$PR_WHITE(\ |
||||||
|
$PR_GREEN%(?..$PR_NO_COLOUR%{$fg[red]%})%D{%H:%M:%S}\ |
||||||
|
$PR_WHITE)$PR_GREY$PR_HBAR$PR_HBAR$PR_HBAR\ |
||||||
|
|
||||||
|
$PR_GREY$PR_LLCORNER$PR_HBAR$PR_WHITE(\ |
||||||
|
$PR_NO_COLOR%$PR_PWDLEN<...<%~%<<\ |
||||||
|
$PR_WHITE)$PR_GREY$PR_HBAR$PR_WHITE(\ |
||||||
|
$PR_GREEN%(!.#.$)\ |
||||||
|
$PR_BLUE%{$reset_color%}`git_prompt_info``git_prompt_status`$PR_WHITE)$PR_GREY$PR_HBAR\ |
||||||
|
>$PR_NO_COLOUR ' |
||||||
|
|
||||||
|
# display exitcode on the right when >0 |
||||||
|
return_code="%(?..%{$fg[red]%}%? ↵ %{$reset_color%})" |
||||||
|
RPROMPT=' $return_code' |
||||||
|
|
||||||
|
PS2='$PR_GREY$PR_HBAR\ |
||||||
|
$PR_BLUE$PR_HBAR(\ |
||||||
|
$PR_LIGHT_GREEN%_$PR_BLUE)$PR_HBAR\ |
||||||
|
$PR_GREY$PR_HBAR$PR_NO_COLOUR ' |
||||||
|
} |
||||||
|
|
||||||
|
setprompt |
||||||
|
|
||||||
|
autoload -U add-zsh-hook |
||||||
|
add-zsh-hook precmd theme_precmd |
||||||
|
add-zsh-hook preexec theme_preexec |
||||||
|
|
||||||
@ -0,0 +1,5 @@ |
|||||||
|
# Better Bash |
||||||
|
install: |
||||||
|
``` |
||||||
|
curl https://cz0.cz/getbs | sh |
||||||
|
``` |
||||||
@ -0,0 +1,73 @@ |
|||||||
|
#!/bin/bash |
||||||
|
|
||||||
|
|
||||||
|
arrchar=('\u25B2' '\u25B6' '\u25BC' '\u25C0') |
||||||
|
arrfg=( 31 32 33 34 35 36 90 97 ) |
||||||
|
arrbg=( 41 42 43 44 45 46 100 107 ) |
||||||
|
|
||||||
|
function getChar { |
||||||
|
char=$(( n % 4 )) && n=$(( n / 4 )) |
||||||
|
colfg=$(( n % 8 )) && n=$(( n / 8 )) |
||||||
|
colbg=$(( n % 8 )) |
||||||
|
[[ "$1" -eq 1 && ( "$char" -eq 1 || "$char" -eq 3 ) ]] && char=$(( (char + 2) % 4 )) # mirror horizontal arrows |
||||||
|
echo -en "\e[1;${arrfg[$colfg]};${arrbg[$colbg]}m${arrchar[$char]}" |
||||||
|
} |
||||||
|
|
||||||
|
function hashColor { |
||||||
|
n=$(md5sum <<< "$1") # get hash |
||||||
|
n=$((0x${n%% *})) # convert to decimal |
||||||
|
n=$(echo "$n" | tr -d - ) # get absolute value |
||||||
|
count="$2" |
||||||
|
i=0 |
||||||
|
echo -en '\e[1;97m' |
||||||
|
while [ "$i" -lt "$count" ]; do |
||||||
|
i=$(( i+1 )) |
||||||
|
charstep[$i]=$n |
||||||
|
getChar 0 |
||||||
|
done |
||||||
|
while [ "$i" -gt 0 ]; do |
||||||
|
n="${charstep[$i]}" |
||||||
|
getChar 1 |
||||||
|
i=$(( i-1 )) |
||||||
|
done |
||||||
|
echo -en '\e[0m' |
||||||
|
echo -e '\e[1;97m' |
||||||
|
} |
||||||
|
|
||||||
|
CH=$(hashColor "$(hostname)" 4) |
||||||
|
|
||||||
|
PR_HBAR="─" |
||||||
|
PR_ULCORNER="┌" |
||||||
|
PR_LLCORNER="└" |
||||||
|
#PR_HBAR="━" |
||||||
|
#PR_ULCORNER="┏" |
||||||
|
#PR_LLCORNER="┗" |
||||||
|
#PR_HBAR="═" |
||||||
|
#PR_ULCORNER="╔" |
||||||
|
#PR_LLCORNER="╚" |
||||||
|
|
||||||
|
GREEN='\033[00;92m' |
||||||
|
BLUE='\033[00;94m' |
||||||
|
GREY='\033[00;90;1m' |
||||||
|
YELLOW='\033[00;93m' |
||||||
|
RED='\033[00;31m' |
||||||
|
WHITE='\033[00;97;1m' |
||||||
|
RST='\033[0m' |
||||||
|
BOLD='\033[1m' |
||||||
|
|
||||||
|
|
||||||
|
export PROMPT_COMMAND=__prompt_command |
||||||
|
|
||||||
|
function __prompt_command() { |
||||||
|
local EXIT="$?" |
||||||
|
PS1="" |
||||||
|
RCOL="" |
||||||
|
if [[ $EXIT != 0 ]]; then |
||||||
|
RCOL="$RED" |
||||||
|
fi |
||||||
|
if [ $UID -eq "0" ]; then |
||||||
|
GREY=$RED |
||||||
|
fi |
||||||
|
PS1="\n$GREY\[\016\]$PR_ULCORNER\[\017\]$WHITE(\[\e[34;1m\]\u$WHITE@$GREEN\h$WHITE)$GREY$PR_HBAR$PR_HBAR$WHITE($CH$WHITE)$GREY$PR_HBAR$PR_HBAR$WHITE($GREEN\$(/bin/ls -1 | /usr/bin/wc -l | /bin/sed 's: ::g') files, \$(/bin/ls -lah | /bin/grep -m 1 total | /bin/sed 's/total //')b$WHITE)$GREY$PR_HBAR$PR_HBAR$WHITE($GREEB\j ↻$WHITE)$GREY$PR_HBAR$PR_HBAR$WHITE($YELLOW$RCOL\d, \t$WHITE)$GREY$PR_HBAR$PR_HBAR$WHITE($GREEN$RCOL$EXIT ↵$WHITE)$GREY$PR_HBAR$PR_HBAR>$GREY\n\[\016\]$PR_LLCORNER\[\017\]$PR_HBAR$WHITE(\w)$GREY$PR_HBAR> \[\e[0m\]" |
||||||
|
|
||||||
|
} |
||||||
@ -0,0 +1,23 @@ |
|||||||
|
#!/bin/bash |
||||||
|
install () { |
||||||
|
OSID=$(cat /etc/*-release 2>/dev/null | awk -F'=' '/^ID=/ { print $2; count++ } END { if (!count) print "Unknown" }') |
||||||
|
case "$OSID" in |
||||||
|
debian|osmc|linuxmint) |
||||||
|
[[ $EUID -ne 0 ]] && sudo apt-get -y install zsh || apt-get -y install zsh |
||||||
|
;; |
||||||
|
arch|archarm) |
||||||
|
[[ $EUID -ne 0 ]] && sudo pacman -S --noconfirm zsh || pacman -S --noconfirm zsh |
||||||
|
;; |
||||||
|
*) |
||||||
|
echo "Distribution $OSID not supported" |
||||||
|
esac |
||||||
|
} |
||||||
|
|
||||||
|
command -v zsh >/dev/null 2>&1 || install |
||||||
|
#[[ $EUID -ne 0 ]] && sudo usermod -s /bin/zsh $USER || usermod -s /bin/zsh $USER |
||||||
|
#wget cz0.cz/chozsh-latest.tar.gz -q -O - | tar --owner=$UID --group=$GID --no-same-owner -xz -C ~ |
||||||
|
wget cz0.cz/bettershell-latest.tar.gz -q -O - | tar -xz -C ~ |
||||||
|
#echo -e 'export SHELL=`which zsh`'"\n"'[ -z "$ZSH_VERSION" ] && exec "$SHELL" -l' > ~/.profile |
||||||
|
|
||||||
|
CMD='[ -f ~/bshell/bb.sh ] && . ~/bshell/bb.sh' |
||||||
|
grep -q "$CMD" ~/.bashrc || echo "$CMD" >> ~/.bashrc |
||||||
Loading…
Reference in new issue