如果别名是命令行上出现的第一个单词,您可以显示别名,您可以尝试将以下代码放入您的 .zshrc 中:
_-accept-line () {
emulate -L zsh
local -a WORDS
WORDS=( ${(z)BUFFER} )
# Unfortunately ${${(z)BUFFER}[1]} works only for at least two words,
# thus I had to use additional variable WORDS here.
local -r FIRSTWORD=${WORDS[1]}
local -r GREEN=$'\e[32m' RESET_COLORS=$'\e[0m'
[[ "$(whence -w $FIRSTWORD 2>/dev/null)" == "${FIRSTWORD}: alias" ]] &&
echo -nE $'\n'"${GREEN}Executing $(whence $FIRSTWORD)${RESET_COLORS}"
zle .accept-line
}
zle -N accept-line _-accept-line
描述(略过一些琐碎的事情):
emulate -L zsh # Reset some options to zsh defaults (locally).
# Makes function immune to user setup.
local -a WORDS # Declare WORDS as an array local to function
${(z)VARNAME} # Split VARNAME using command-line parser.
# Things like “"first word" "second word"” get split into 2 words:
# “"first word"” “"second word"”
$BUFFER # Variable containing the whole command-line. Can be modified
local -r V # Declare variable “V” as read-only
$'\e[32m' # Escape code for green foreground color in most terminals
$'\e[0m' # Sequence that being echoed to terminal clears out color information
whence -w cmd # Display type of the command in format “cmd: type”
whence cmd # If “cmd” is an alias, then this command outputs alias value
zle .accept-line # Call internal zle “accept-line” widget. This must be done or
# every command will turn to no-op. You can, of course, replace
# this with “eval $BUFFER” but I can’t say what will break in this case
zle -N accept-line _-accept-line # Associate widget “accept-line” with function
# “_-accept-line”. This makes this function responsible for accepting
# lines.
man zshbuiltins
( emulate
, whence
, local
), man zshzle
( zle
, $BUFFER
), man zshparam
( )中的更多信息${(z)}
。