suspend suggestions on fast changes

This commit is contained in:
Stanislav Seletskiy 2016-04-21 03:07:24 +06:00
parent 87facd9b85
commit 7d41cf90c8
3 changed files with 32 additions and 0 deletions

View file

@ -1,3 +1,4 @@
zmodload zsh/datetime
#--------------------------------------------------------------------#
# Global Configuration Variables #
@ -46,3 +47,10 @@ ZSH_AUTOSUGGEST_PARTIAL_ACCEPT_WIDGETS=(
vi-forward-blank-word
vi-forward-blank-word-end
)
# EPOCH of the last changed widget call
ZSH_AUTOSUGGEST_LAST_MODIFY_TIME=$EPOCHREALTIME
# Lower bound for the time between changes that will cause autosuggest
# to suspend suggestions for the current edit.
ZSH_AUTOSUGGEST_CUTOFF_PERIOD=0.05

View file

@ -16,6 +16,14 @@ _zsh_autosuggest_modify() {
# Original widget modifies the buffer
_zsh_autosuggest_invoke_original_widget $@
local time_passed=$(($EPOCHREALTIME - $ZSH_AUTOSUGGEST_LAST_MODIFY_TIME))
if (( $time_passed < $ZSH_AUTOSUGGEST_CUTOFF_PERIOD )); then
return 1
fi
ZSH_AUTOSUGGEST_LAST_MODIFY_TIME=$EPOCHREALTIME
# Get a new suggestion if the buffer is not empty after modification
local suggestion
if [ $#BUFFER -gt 0 ]; then

View file

@ -24,6 +24,7 @@
# WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
# FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR
# OTHER DEALINGS IN THE SOFTWARE.
zmodload zsh/datetime
#--------------------------------------------------------------------#
# Global Configuration Variables #
@ -73,6 +74,13 @@ ZSH_AUTOSUGGEST_PARTIAL_ACCEPT_WIDGETS=(
vi-forward-blank-word-end
)
# EPOCH of the last changed widget call
ZSH_AUTOSUGGEST_LAST_MODIFY_TIME=$EPOCHREALTIME
# Lower bound for the time between changes that will cause autosuggest
# to suspend suggestions for the current edit.
ZSH_AUTOSUGGEST_CUTOFF_PERIOD=0.05
#--------------------------------------------------------------------#
# Handle Deprecated Variables/Widgets #
#--------------------------------------------------------------------#
@ -233,6 +241,14 @@ _zsh_autosuggest_modify() {
# Original widget modifies the buffer
_zsh_autosuggest_invoke_original_widget $@
local time_passed=$(($EPOCHREALTIME - $ZSH_AUTOSUGGEST_LAST_MODIFY_TIME))
if (( $time_passed < $ZSH_AUTOSUGGEST_CUTOFF_PERIOD )); then
return 1
fi
ZSH_AUTOSUGGEST_LAST_MODIFY_TIME=$EPOCHREALTIME
# Get a new suggestion if the buffer is not empty after modification
local suggestion
if [ $#BUFFER -gt 0 ]; then