From bd4a3503d2c783556e69ab49ff77fd4e188cd91f Mon Sep 17 00:00:00 2001 From: romkatv Date: Sun, 19 May 2019 09:11:39 +0200 Subject: [PATCH] support multiple markers with POWERLEVEL9K_SHORTEN_STRATEGY=truncate_with_folder_marker --- powerlevel9k.zsh-theme | 40 +++++++++++++++++++++------------------- 1 file changed, 21 insertions(+), 19 deletions(-) diff --git a/powerlevel9k.zsh-theme b/powerlevel9k.zsh-theme index 85a8f6e9..41ace8d4 100755 --- a/powerlevel9k.zsh-theme +++ b/powerlevel9k.zsh-theme @@ -784,11 +784,6 @@ prompt_command_execution_time() { "$1_prompt_segment" "$0" "$2" "red" "yellow1" 'EXECUTION_TIME_ICON' 0 '' "${humanReadableDuration}" } -################################################################ -# Dir: current working directory -# Parameters: -# * $1 Alignment: string - left|right -# * $2 Index: integer set_default POWERLEVEL9K_DIR_PATH_SEPARATOR "/" set_default POWERLEVEL9K_HOME_FOLDER_ABBREVIATION "~" set_default POWERLEVEL9K_DIR_PATH_HIGHLIGHT_BOLD false @@ -798,9 +793,15 @@ set_default POWERLEVEL9K_DIR_OMIT_FIRST_CHARACTER false set_default POWERLEVEL9K_SHORTEN_STRATEGY "" set_default POWERLEVEL9K_DIR_PATH_SEPARATOR_FOREGROUND "" set_default POWERLEVEL9K_SHORTEN_DELIMITER $'\u2026' +# This defines a pattern. It is expanded with the options set by `emulate zsh`. +# This works pretty well: POWERLEVEL9K_SHORTEN_FOLDER_MARKER="(.bzr|CVS|.git|.hg|.svn|.citc)" set_default POWERLEVEL9K_SHORTEN_FOLDER_MARKER ".shorten_folder_marker" set_default -i POWERLEVEL9K_SHORTEN_DIR_LENGTH -1 +# Individual elements are patterns. They are expanded with the options set by `emulate zsh`. set_default -a POWERLEVEL9K_DIR_PACKAGE_FILES package.json composer.json + +################################################################ +# Dir: current working directory prompt_dir() { [[ $POWERLEVEL9K_DIR_PATH_ABSOLUTE == true ]] && local p=$PWD || local p=${(%):-%~} @@ -851,21 +852,21 @@ prompt_dir() { ;; truncate_with_package_name|truncate_middle|truncate_from_right) () { - [[ $POWERLEVEL9K_SHORTEN_STRATEGY == truncate_with_package_name ]] || return + [[ $POWERLEVEL9K_SHORTEN_STRATEGY == truncate_with_package_name && + $+commands[jq] == 1 && $#POWERLEVEL9K_DIR_PACKAGE_FILES > 0 ]] || return + local pat="(${(j:|:)POWERLEVEL9K_DIR_PACKAGE_FILES})" local -i i=$#parts - local pkg_dir=$PWD + local dir=$PWD for (( ; i > 0; --i )); do - local fname='' - for fname in $POWERLEVEL9K_DIR_PACKAGE_FILES; do - if [[ -f $pkg_dir/$fname ]]; then - local pkg_name='' - pkg_name=$(jq -j '.name' <$pkg_dir/$fname) && [[ -n $pkg_name ]] || return - parts[1,i]=($pkg_name) - fake_first=1 - return - fi + local pkg_file='' + for pkg_file in $dir/${~pat}(N); do + local pkg_name='' + pkg_name=$(command jq -j '.name' <$pkg_file) && [[ -n $pkg_name ]] || return + parts[1,i]=($pkg_name) + fake_first=1 + return done - pkg_dir=${pkg_dir:h} + dir=${dir:h} done } if (( POWERLEVEL9K_SHORTEN_DIR_LENGTH > 0 )); then @@ -900,7 +901,7 @@ prompt_dir() { local dir=$parts[i] local -i j=1 for (( ; j <= $#dir; ++j )); do - local -a matching=($parent/$dir[1,j]*/) + local -a matching=($parent/$dir[1,j]*/(N)) (( $#matching == 1 )) && break done parent+=/$dir @@ -913,7 +914,8 @@ prompt_dir() { local -i i=$(($#parts - 1)) for (( ; i > 1; --i )); do dir=${dir:h} - [[ -e $dir/$POWERLEVEL9K_SHORTEN_FOLDER_MARKER ]] && m+=$i + local -a matches=($dir/${~POWERLEVEL9K_SHORTEN_FOLDER_MARKER}(N)) + (( $#matches )) && m+=$i done m+=1 for (( i=1; i < $#m; ++i )); do