mirror of
git://git.code.sf.net/p/zsh/code
synced 2025-10-28 17:10:59 +01:00
32866: new replace-argument ZLE function.
Also a couple of read-from-minibuffer fixes: don't pass numeric argument to recursive edit, and hide the minibuffer edit from the undo history.
This commit is contained in:
parent
7d5db0d277
commit
4e54648add
4 changed files with 89 additions and 0 deletions
|
|
@ -1,3 +1,12 @@
|
||||||
|
2014-07-17 Peter Stephenson <p.stephenson@samsung.com>
|
||||||
|
|
||||||
|
* 32866 (plus extra undo fix in read-from-minibuffer):
|
||||||
|
Doc/Zsh/contrib.yo, Functions/Zle/read-from-minibuffer,
|
||||||
|
Functions/Zle/replace-argument: new replace-argument function;
|
||||||
|
fixes in read-from-minibuffer not to pass through numeric
|
||||||
|
argument to recursive edit and to hide minibuffer edit from
|
||||||
|
undo history.
|
||||||
|
|
||||||
2014-07-08 Peter Stephenson <p.stephenson@samsung.com>
|
2014-07-08 Peter Stephenson <p.stephenson@samsung.com>
|
||||||
|
|
||||||
* Dominic Hopf: 32837: Config/defs.mk.in: improve handling of
|
* Dominic Hopf: 32837: Config/defs.mk.in: improve handling of
|
||||||
|
|
|
||||||
|
|
@ -2328,6 +2328,31 @@ The name is a slight misnomer, as in fact the shell's own minibuffer is
|
||||||
not used. Hence it is still possible to call tt(executed-named-cmd) and
|
not used. Hence it is still possible to call tt(executed-named-cmd) and
|
||||||
similar functions while reading a value.
|
similar functions while reading a value.
|
||||||
)
|
)
|
||||||
|
tindex(replace-argument)
|
||||||
|
tindex(replace-argument-edit)
|
||||||
|
item(tt(replace-argument), tt(replace-argument-edit))
|
||||||
|
(
|
||||||
|
The function tt(replace-argument) can be used to replace a command
|
||||||
|
line argument in the current command line or, if the current command
|
||||||
|
line is empty, in the last command line executed (the new command line
|
||||||
|
is not executed). Arguments are as delimited by standard shell syntax,
|
||||||
|
|
||||||
|
If a numeric argument is given, that specifies the argument to be
|
||||||
|
replaced. 0 means the command name, as in history expansion.
|
||||||
|
|
||||||
|
If no numeric argument is given, the current argument is replaced;
|
||||||
|
this is the last argument if the previous history line is being used.
|
||||||
|
|
||||||
|
The function prompts for a replacement argument.
|
||||||
|
|
||||||
|
If the widget contains the string tt(edit), for example is defined as
|
||||||
|
|
||||||
|
example(zle -N replace-argument-edit replace-argument)
|
||||||
|
|
||||||
|
then the function presents the current value of the argument for
|
||||||
|
editing, otherwise the editing buffer for the replacement is
|
||||||
|
initially empty.
|
||||||
|
)
|
||||||
tindex(replace-string)
|
tindex(replace-string)
|
||||||
tindex(replace-string-again)
|
tindex(replace-string-again)
|
||||||
tindex(replace-pattern)
|
tindex(replace-pattern)
|
||||||
|
|
|
||||||
|
|
@ -20,7 +20,9 @@ done
|
||||||
(( OPTIND > 1 )) && shift $(( OPTIND - 1 ))
|
(( OPTIND > 1 )) && shift $(( OPTIND - 1 ))
|
||||||
|
|
||||||
local readprompt="$1" lbuf_init="$2" rbuf_init="$3"
|
local readprompt="$1" lbuf_init="$2" rbuf_init="$3"
|
||||||
|
integer changeno=$UNDO_CHANGE_NO
|
||||||
|
|
||||||
|
{
|
||||||
# Use anonymous function to make sure special values get restored,
|
# Use anonymous function to make sure special values get restored,
|
||||||
# even if this function is called as a widget.
|
# even if this function is called as a widget.
|
||||||
# local +h ensures special parameters stay special.
|
# local +h ensures special parameters stay special.
|
||||||
|
|
@ -39,10 +41,17 @@ local readprompt="$1" lbuf_init="$2" rbuf_init="$3"
|
||||||
read -k $keys
|
read -k $keys
|
||||||
stat=$?
|
stat=$?
|
||||||
else
|
else
|
||||||
|
local NUMERIC
|
||||||
|
unset NUMERIC
|
||||||
zle recursive-edit -K main
|
zle recursive-edit -K main
|
||||||
stat=$?
|
stat=$?
|
||||||
(( stat )) || REPLY=$BUFFER
|
(( stat )) || REPLY=$BUFFER
|
||||||
fi
|
fi
|
||||||
}
|
}
|
||||||
|
} always {
|
||||||
|
# This removes the edits relating to the read from the undo history.
|
||||||
|
# These aren't useful once we get back to the main editing buffer.
|
||||||
|
zle undo $changeno
|
||||||
|
}
|
||||||
|
|
||||||
return $stat
|
return $stat
|
||||||
|
|
|
||||||
46
Functions/Zle/replace-argument
Normal file
46
Functions/Zle/replace-argument
Normal file
|
|
@ -0,0 +1,46 @@
|
||||||
|
# Replace an argument to a command, delimited by normal shell syntax.
|
||||||
|
# Prompts for the replacement.
|
||||||
|
# With no numeric argument, replace the current argument.
|
||||||
|
# With a numeric argument, replace that argument: 0 = command word,
|
||||||
|
# as in history expansion.
|
||||||
|
# If editing buffer is empty, use previous history line.
|
||||||
|
|
||||||
|
autoload -Uz split-shell-arguments read-from-minibuffer
|
||||||
|
|
||||||
|
if (( ${#BUFFER} == 0 )); then
|
||||||
|
(( HISTNO-- ))
|
||||||
|
CURSOR=${#BUFFER}
|
||||||
|
fi
|
||||||
|
|
||||||
|
local widget=$WIDGET
|
||||||
|
integer numeric cursor=CURSOR
|
||||||
|
if (( ${+NUMERIC} )); then
|
||||||
|
numeric=$NUMERIC
|
||||||
|
else
|
||||||
|
numeric=-1
|
||||||
|
fi
|
||||||
|
local reply REPLY REPLY2
|
||||||
|
integer index
|
||||||
|
split-shell-arguments
|
||||||
|
|
||||||
|
if (( numeric >= 0 )); then
|
||||||
|
index=$(( 2 + 2*numeric ))
|
||||||
|
else
|
||||||
|
index=$((REPLY & ~1 ))
|
||||||
|
fi
|
||||||
|
|
||||||
|
local edit
|
||||||
|
if [[ $widget = *edit* ]]; then
|
||||||
|
edit=$reply[$index]
|
||||||
|
fi
|
||||||
|
read-from-minibuffer "Replace $reply[$index] with: " $edit || return 1
|
||||||
|
|
||||||
|
integer diff=$(( ${#REPLY} - ${#reply[$index]} ))
|
||||||
|
reply[$index]=$REPLY
|
||||||
|
|
||||||
|
BUFFER=${(j..)reply}
|
||||||
|
if (( cursor > REPLY2 )); then
|
||||||
|
(( CURSOR = cursor + diff ))
|
||||||
|
else
|
||||||
|
(( CURSOR = REPLY2 ))
|
||||||
|
fi
|
||||||
Loading…
Add table
Add a link
Reference in a new issue