|
|
# .p10k.zsh -- Samuel FORESTIER |
|
|
|
|
|
# (Originally) generated by Powerlevel10k configuration wizard. |
|
|
# Based on romkatv/powerlevel10k/config/p10k-rainbow.zsh, checksum 20557. |
|
|
# Type `p10k configure` to generate another config. |
|
|
|
|
|
|
|
|
# Temporarily change options. |
|
|
'builtin' 'local' '-a' 'p10k_config_opts' |
|
|
[[ ! -o 'aliases' ]] || p10k_config_opts+=('aliases') |
|
|
[[ ! -o 'sh_glob' ]] || p10k_config_opts+=('sh_glob') |
|
|
[[ ! -o 'no_brace_expand' ]] || p10k_config_opts+=('no_brace_expand') |
|
|
'builtin' 'setopt' 'no_aliases' 'no_sh_glob' 'brace_expand' |
|
|
|
|
|
|
|
|
() { |
|
|
emulate -L zsh -o extended_glob |
|
|
|
|
|
# Unset all configuration options. |
|
|
unset -m 'POWERLEVEL9K_*' |
|
|
|
|
|
# Zsh >= 5.1 is required. |
|
|
autoload -Uz is-at-least && is-at-least 5.1 || return |
|
|
|
|
|
# The list of segments shown on the left. |
|
|
typeset -g POWERLEVEL9K_LEFT_PROMPT_ELEMENTS=( |
|
|
os_icon |
|
|
dir |
|
|
vcs |
|
|
virtualenv |
|
|
) |
|
|
|
|
|
# The list of segments shown on the right. |
|
|
typeset -g POWERLEVEL9K_RIGHT_PROMPT_ELEMENTS=( |
|
|
status |
|
|
background_jobs |
|
|
command_execution_time |
|
|
time |
|
|
) |
|
|
|
|
|
# Defines character set used by powerlevel10k. |
|
|
typeset -g POWERLEVEL9K_MODE=nerdfont-complete |
|
|
typeset -g POWERLEVEL9K_ICON_PADDING=none |
|
|
|
|
|
# When set to true, icons appear before content on both sides of the prompt. |
|
|
typeset -g POWERLEVEL9K_ICON_BEFORE_CONTENT=true |
|
|
|
|
|
# Don't add an empty line before each prompt. |
|
|
typeset -g POWERLEVEL9K_PROMPT_ADD_NEWLINE=false |
|
|
|
|
|
# Separator between same-color segments on the left. |
|
|
typeset -g POWERLEVEL9K_LEFT_SUBSEGMENT_SEPARATOR='\uE0B1' |
|
|
# Separator between same-color segments on the right. |
|
|
typeset -g POWERLEVEL9K_RIGHT_SUBSEGMENT_SEPARATOR='\uE0B3' |
|
|
# Separator between different-color segments on the left. |
|
|
typeset -g POWERLEVEL9K_LEFT_SEGMENT_SEPARATOR='\uE0B0' |
|
|
# Separator between different-color segments on the right. |
|
|
typeset -g POWERLEVEL9K_RIGHT_SEGMENT_SEPARATOR='\uE0B2' |
|
|
# The right end of left prompt. |
|
|
typeset -g POWERLEVEL9K_LEFT_PROMPT_LAST_SEGMENT_END_SYMBOL='\uE0B0' |
|
|
# The left end of right prompt. |
|
|
typeset -g POWERLEVEL9K_RIGHT_PROMPT_FIRST_SEGMENT_START_SYMBOL='\uE0B2' |
|
|
# The left end of left prompt. |
|
|
typeset -g POWERLEVEL9K_LEFT_PROMPT_FIRST_SEGMENT_START_SYMBOL='' |
|
|
# The right end of right prompt. |
|
|
typeset -g POWERLEVEL9K_RIGHT_PROMPT_LAST_SEGMENT_END_SYMBOL='' |
|
|
# Left prompt terminator for lines without any segments. |
|
|
typeset -g POWERLEVEL9K_EMPTY_LINE_LEFT_PROMPT_LAST_SEGMENT_END_SYMBOL= |
|
|
|
|
|
#################################[ os_icon: os identifier ]################################## |
|
|
# OS identifier color. |
|
|
typeset -g POWERLEVEL9K_OS_ICON_FOREGROUND=232 |
|
|
typeset -g POWERLEVEL9K_OS_ICON_BACKGROUND=7 |
|
|
|
|
|
##################################[ dir: current directory ]################################## |
|
|
# Current directory background color. |
|
|
# typeset -g POWERLEVEL9K_DIR_BACKGROUND=4 |
|
|
# Default current directory foreground color. |
|
|
typeset -g POWERLEVEL9K_DIR_FOREGROUND=254 |
|
|
# If directory is too long, shorten some of its segments to the shortest possible unique |
|
|
# prefix. The shortened directory can be tab-completed to the original. |
|
|
typeset -g POWERLEVEL9K_SHORTEN_STRATEGY=truncate_to_unique |
|
|
# Replace removed segment suffixes with this symbol. |
|
|
typeset -g POWERLEVEL9K_SHORTEN_DELIMITER= |
|
|
# Color of the shortened directory segments. |
|
|
typeset -g POWERLEVEL9K_DIR_SHORTENED_FOREGROUND=250 |
|
|
# Color of the anchor directory segments. Anchor segments are never shortened. The first |
|
|
# segment is always an anchor. |
|
|
typeset -g POWERLEVEL9K_DIR_ANCHOR_FOREGROUND=255 |
|
|
# Display anchor directory segments in bold. |
|
|
typeset -g POWERLEVEL9K_DIR_ANCHOR_BOLD=true |
|
|
# Don't shorten directories that contain any of these files. They are anchors. |
|
|
local anchor_files=( |
|
|
.bzr |
|
|
.citc |
|
|
.git |
|
|
.hg |
|
|
.node-version |
|
|
.python-version |
|
|
.go-version |
|
|
.ruby-version |
|
|
.lua-version |
|
|
.java-version |
|
|
.perl-version |
|
|
.php-version |
|
|
.tool-version |
|
|
.shorten_folder_marker |
|
|
.svn |
|
|
.terraform |
|
|
CVS |
|
|
Cargo.toml |
|
|
composer.json |
|
|
go.mod |
|
|
package.json |
|
|
stack.yaml |
|
|
) |
|
|
typeset -g POWERLEVEL9K_SHORTEN_FOLDER_MARKER="(${(j:|:)anchor_files})" |
|
|
# If set to true, remove everything before the last (deepest) subdirectory that contains files |
|
|
# matching $POWERLEVEL9K_SHORTEN_FOLDER_MARKER. |
|
|
typeset -g POWERLEVEL9K_DIR_TRUNCATE_BEFORE_MARKER=false |
|
|
# Don't shorten this many last directory segments. They are anchors. |
|
|
typeset -g POWERLEVEL9K_SHORTEN_DIR_LENGTH=1 |
|
|
# Shorten directory if it's longer than this even if there is space for it. The value can |
|
|
# be either absolute (e.g., '80') or a percentage of terminal width (e.g, '50%'). If empty, |
|
|
# directory will be shortened only when prompt doesn't fit or when other parameters demand it |
|
|
# (see POWERLEVEL9K_DIR_MIN_COMMAND_COLUMNS and POWERLEVEL9K_DIR_MIN_COMMAND_COLUMNS_PCT below). |
|
|
# If set to `0`, directory will always be shortened to its minimum length. |
|
|
typeset -g POWERLEVEL9K_DIR_MAX_LENGTH=80 |
|
|
# When `dir` segment is on the last prompt line, try to shorten it enough to leave at least this |
|
|
# many columns for typing commands. |
|
|
typeset -g POWERLEVEL9K_DIR_MIN_COMMAND_COLUMNS=40 |
|
|
# When `dir` segment is on the last prompt line, try to shorten it enough to leave at least |
|
|
# COLUMNS * POWERLEVEL9K_DIR_MIN_COMMAND_COLUMNS_PCT * 0.01 columns for typing commands. |
|
|
typeset -g POWERLEVEL9K_DIR_MIN_COMMAND_COLUMNS_PCT=50 |
|
|
# If set to true, embed a hyperlink into the directory. Useful for quickly |
|
|
# opening a directory in the file manager simply by clicking the link. |
|
|
# Can also be handy when the directory is shortened, as it allows you to see |
|
|
# the full directory that was used in previous commands. |
|
|
typeset -g POWERLEVEL9K_DIR_HYPERLINK=true |
|
|
|
|
|
# Enable special styling for non-writable directories. |
|
|
typeset -g POWERLEVEL9K_DIR_SHOW_WRITABLE=true |
|
|
# Show this icon when the current directory is not writable. |
|
|
typeset -g POWERLEVEL9K_DIR_NOT_WRITABLE_VISUAL_IDENTIFIER_EXPANSION='' |
|
|
|
|
|
#####################################[ vcs: git status ]###################################### |
|
|
# Branch icon. |
|
|
typeset -g POWERLEVEL9K_VCS_BRANCH_ICON='\uF126 ' |
|
|
|
|
|
# Untracked files icon. |
|
|
typeset -g POWERLEVEL9K_VCS_UNTRACKED_ICON='?' |
|
|
|
|
|
# Formatter for Git status. |
|
|
# |
|
|
# Example output: master ⇣42⇡42 *42 merge ~42 +42 !42 ?42. |
|
|
# |
|
|
# You can edit the function to customize how Git status looks. |
|
|
# |
|
|
# VCS_STATUS_* parameters are set by gitstatus plugin. See reference: |
|
|
# https://github.com/romkatv/gitstatus/blob/master/gitstatus.plugin.zsh. |
|
|
function my_git_formatter() { |
|
|
emulate -L zsh |
|
|
|
|
|
if [[ -n $P9K_CONTENT ]]; then |
|
|
# If P9K_CONTENT is not empty, use it. It's either "loading" or from vcs_info (not from |
|
|
# gitstatus plugin). VCS_STATUS_* parameters are not available in this case. |
|
|
typeset -g my_git_format=$P9K_CONTENT |
|
|
return |
|
|
fi |
|
|
|
|
|
# Styling for different parts of Git status. |
|
|
local meta='%7F' # white foreground |
|
|
local clean='%0F' # black foreground |
|
|
local modified='%0F' # black foreground |
|
|
local untracked='%0F' # black foreground |
|
|
local conflicted='%1F' # red foreground |
|
|
|
|
|
local res |
|
|
local where # branch or tag |
|
|
if [[ -n $VCS_STATUS_LOCAL_BRANCH ]]; then |
|
|
res+="${clean}${(g::)POWERLEVEL9K_VCS_BRANCH_ICON}" |
|
|
where=${(V)VCS_STATUS_LOCAL_BRANCH} |
|
|
elif [[ -n $VCS_STATUS_TAG ]]; then |
|
|
res+="${meta}#" |
|
|
where=${(V)VCS_STATUS_TAG} |
|
|
fi |
|
|
|
|
|
# If local branch name or tag is at most 32 characters long, show it in full. |
|
|
# Otherwise show the first 12 … the last 12. |
|
|
# Tip: To always show local branch name in full without truncation, delete the next line. |
|
|
(( $#where > 32 )) && where[13,-13]="…" |
|
|
res+="${clean}${where//\%/%%}" # escape % |
|
|
|
|
|
# Display the current Git commit if there is no branch or tag. |
|
|
# Tip: To always display the current Git commit, remove `[[ -z $where ]] &&` from the next line. |
|
|
[[ -z $where ]] && res+="${meta}@${clean}${VCS_STATUS_COMMIT[1,8]}" |
|
|
|
|
|
# Show tracking branch name if it differs from local branch. |
|
|
if [[ -n ${VCS_STATUS_REMOTE_BRANCH:#$VCS_STATUS_LOCAL_BRANCH} ]]; then |
|
|
res+="${meta}:${clean}${(V)VCS_STATUS_REMOTE_BRANCH//\%/%%}" # escape % |
|
|
fi |
|
|
|
|
|
# ⇣42 if behind the remote. |
|
|
(( VCS_STATUS_COMMITS_BEHIND )) && res+=" ${clean}⇣${VCS_STATUS_COMMITS_BEHIND}" |
|
|
# ⇡42 if ahead of the remote; no leading space if also behind the remote: ⇣42⇡42. |
|
|
(( VCS_STATUS_COMMITS_AHEAD && !VCS_STATUS_COMMITS_BEHIND )) && res+=" " |
|
|
(( VCS_STATUS_COMMITS_AHEAD )) && res+="${clean}⇡${VCS_STATUS_COMMITS_AHEAD}" |
|
|
# ⇠42 if behind the push remote. |
|
|
(( VCS_STATUS_PUSH_COMMITS_BEHIND )) && res+=" ${clean}⇠${VCS_STATUS_PUSH_COMMITS_BEHIND}" |
|
|
(( VCS_STATUS_PUSH_COMMITS_AHEAD && !VCS_STATUS_PUSH_COMMITS_BEHIND )) && res+=" " |
|
|
# ⇢42 if ahead of the push remote; no leading space if also behind: ⇠42⇢42. |
|
|
(( VCS_STATUS_PUSH_COMMITS_AHEAD )) && res+="${clean}⇢${VCS_STATUS_PUSH_COMMITS_AHEAD}" |
|
|
# *42 if have stashes. |
|
|
(( VCS_STATUS_STASHES )) && res+=" ${clean}*${VCS_STATUS_STASHES}" |
|
|
# 'merge' if the repo is in an unusual state. |
|
|
[[ -n $VCS_STATUS_ACTION ]] && res+=" ${conflicted}${VCS_STATUS_ACTION}" |
|
|
# ~42 if have merge conflicts. |
|
|
(( VCS_STATUS_NUM_CONFLICTED )) && res+=" ${conflicted}~${VCS_STATUS_NUM_CONFLICTED}" |
|
|
# +42 if have staged changes. |
|
|
(( VCS_STATUS_NUM_STAGED )) && res+=" ${modified}+${VCS_STATUS_NUM_STAGED}" |
|
|
# !42 if have unstaged changes. |
|
|
(( VCS_STATUS_NUM_UNSTAGED )) && res+=" ${modified}!${VCS_STATUS_NUM_UNSTAGED}" |
|
|
# ?42 if have untracked files. It's really a question mark, your font isn't broken. |
|
|
# See POWERLEVEL9K_VCS_UNTRACKED_ICON above if you want to use a different icon. |
|
|
# Remove the next line if you don't want to see untracked files at all. |
|
|
(( VCS_STATUS_NUM_UNTRACKED )) && res+=" ${untracked}${(g::)POWERLEVEL9K_VCS_UNTRACKED_ICON}${VCS_STATUS_NUM_UNTRACKED}" |
|
|
# "─" if the number of unstaged files is unknown. This can happen due to |
|
|
# POWERLEVEL9K_VCS_MAX_INDEX_SIZE_DIRTY (see below) being set to a non-negative number lower |
|
|
# than the number of files in the Git index, or due to bash.showDirtyState being set to false |
|
|
# in the repository config. The number of staged and untracked files may also be unknown |
|
|
# in this case. |
|
|
(( VCS_STATUS_HAS_UNSTAGED == -1 )) && res+=" ${modified}─" |
|
|
|
|
|
typeset -g my_git_format=$res |
|
|
} |
|
|
functions -M my_git_formatter 2>/dev/null |
|
|
|
|
|
# Don't count the number of unstaged, untracked and conflicted files in Git repositories with |
|
|
# more than this many files in the index. Negative value means infinity. |
|
|
typeset -g POWERLEVEL9K_VCS_MAX_INDEX_SIZE_DIRTY=-1 |
|
|
|
|
|
# Don't show Git status in prompt for repositories whose workdir matches this pattern. |
|
|
typeset -g POWERLEVEL9K_VCS_DISABLED_WORKDIR_PATTERN= |
|
|
|
|
|
# Disable the default Git status formatting. |
|
|
typeset -g POWERLEVEL9K_VCS_DISABLE_GITSTATUS_FORMATTING=true |
|
|
# Install our own Git status formatter. |
|
|
typeset -g POWERLEVEL9K_VCS_CONTENT_EXPANSION='${$((my_git_formatter()))+${my_git_format}}' |
|
|
# Enable counters for staged, unstaged, etc. |
|
|
typeset -g POWERLEVEL9K_VCS_{STAGED,UNSTAGED,UNTRACKED,CONFLICTED,COMMITS_AHEAD,COMMITS_BEHIND}_MAX_NUM=-1 |
|
|
|
|
|
# Don't show any VCS icon as we only use git as back-end (see next option). |
|
|
typeset -g POWERLEVEL9K_VCS_VISUAL_IDENTIFIER_EXPANSION= |
|
|
|
|
|
# Show status of repositories of these types. |
|
|
typeset -g POWERLEVEL9K_VCS_BACKENDS=(git) |
|
|
|
|
|
###[ virtualenv: python virtual environment (https://docs.python.org/3/library/venv.html) ]### |
|
|
# Python virtual environment color. |
|
|
typeset -g POWERLEVEL9K_VIRTUALENV_BACKGROUND=214 |
|
|
# Don't show Python version next to the virtual environment name. |
|
|
typeset -g POWERLEVEL9K_VIRTUALENV_SHOW_PYTHON_VERSION=false |
|
|
# Remove parenthesis delimiters around virtual environment name. |
|
|
typeset -g POWERLEVEL9K_VIRTUALENV_LEFT_DELIMITER= |
|
|
typeset -g POWERLEVEL9K_VIRTUALENV_RIGHT_DELIMITER= |
|
|
|
|
|
##########################[ status: exit code of the last command ]########################### |
|
|
# Enable OK_PIPE, ERROR_PIPE and ERROR_SIGNAL status states to allow us to enable, disable and |
|
|
# style them independently from the regular OK and ERROR state. |
|
|
typeset -g POWERLEVEL9K_STATUS_EXTENDED_STATES=true |
|
|
|
|
|
# Status on success. |
|
|
typeset -g POWERLEVEL9K_STATUS_OK=true |
|
|
typeset -g POWERLEVEL9K_STATUS_OK_VISUAL_IDENTIFIER_EXPANSION='✔' |
|
|
|
|
|
# Status when some part of a pipe command fails but the overall exit status is zero. It may look |
|
|
# like this: 1|0. |
|
|
typeset -g POWERLEVEL9K_STATUS_OK_PIPE=true |
|
|
typeset -g POWERLEVEL9K_STATUS_OK_PIPE_VISUAL_IDENTIFIER_EXPANSION='✔' |
|
|
|
|
|
# Status when it's just an error code (e.g., '1'). |
|
|
typeset -g POWERLEVEL9K_STATUS_ERROR=true |
|
|
typeset -g POWERLEVEL9K_STATUS_ERROR_VISUAL_IDENTIFIER_EXPANSION='✘' |
|
|
|
|
|
# Status when the last command was terminated by a signal. |
|
|
typeset -g POWERLEVEL9K_STATUS_ERROR_SIGNAL=true |
|
|
typeset -g POWERLEVEL9K_STATUS_VERBOSE_SIGNAME=true |
|
|
typeset -g POWERLEVEL9K_STATUS_ERROR_SIGNAL_VISUAL_IDENTIFIER_EXPANSION='✘' |
|
|
|
|
|
# Status when some part of a pipe command fails and the overall exit status is also non-zero. |
|
|
# It may look like this: 1|0. |
|
|
typeset -g POWERLEVEL9K_STATUS_ERROR_PIPE=true |
|
|
typeset -g POWERLEVEL9K_STATUS_ERROR_PIPE_VISUAL_IDENTIFIER_EXPANSION='✘' |
|
|
|
|
|
###################[ command_execution_time: duration of the last command ]################### |
|
|
# Execution time color. |
|
|
typeset -g POWERLEVEL9K_COMMAND_EXECUTION_TIME_FOREGROUND=0 |
|
|
typeset -g POWERLEVEL9K_COMMAND_EXECUTION_TIME_BACKGROUND=3 |
|
|
# Show duration of the last command if takes longer than this many seconds. |
|
|
typeset -g POWERLEVEL9K_COMMAND_EXECUTION_TIME_THRESHOLD=2 |
|
|
# Show this many fractional digits. Zero means round to seconds. |
|
|
typeset -g POWERLEVEL9K_COMMAND_EXECUTION_TIME_PRECISION=0 |
|
|
# Duration format: 1d 2h 3m 4s. |
|
|
typeset -g POWERLEVEL9K_COMMAND_EXECUTION_TIME_FORMAT='d h m s' |
|
|
|
|
|
#######################[ background_jobs: presence of background jobs ]####################### |
|
|
# Show the number of background jobs. |
|
|
typeset -g POWERLEVEL9K_BACKGROUND_JOBS_VERBOSE=true |
|
|
|
|
|
####################################[ time: current time ]#################################### |
|
|
# Format for the current time: 09:51:02. See `man 3 strftime`. |
|
|
typeset -g POWERLEVEL9K_TIME_FORMAT='%D{%H:%M:%S}' |
|
|
# If set to true, time will update when you hit enter. |
|
|
typeset -g POWERLEVEL9K_TIME_UPDATE_ON_COMMAND=true |
|
|
|
|
|
# Transient prompt mode. |
|
|
typeset -g POWERLEVEL9K_TRANSIENT_PROMPT=off |
|
|
|
|
|
# Instant prompt mode. |
|
|
typeset -g POWERLEVEL9K_INSTANT_PROMPT=verbose |
|
|
|
|
|
# Hot reload allows you to change POWERLEVEL9K options after Powerlevel10k has been initialized. |
|
|
typeset -g POWERLEVEL9K_DISABLE_HOT_RELOAD=true |
|
|
|
|
|
# If p10k is already loaded, reload configuration. |
|
|
(( ! $+functions[p10k] )) || p10k reload |
|
|
} |
|
|
|
|
|
# Tell `p10k configure` which file it should overwrite. |
|
|
typeset -g POWERLEVEL9K_CONFIG_FILE=${${(%):-%x}:a} |
|
|
|
|
|
(( ${#p10k_config_opts} )) && setopt ${p10k_config_opts[@]} |
|
|
'builtin' 'unset' 'p10k_config_opts'
|
|
|
|