334 lines
14 KiB
Bash
334 lines
14 KiB
Bash
# .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'
|