mirror of
				https://github.com/zsh-users/zsh-autosuggestions.git
				synced 2024-05-11 05:54:57 +00:00 
			
		
		
		
	Revert "Simplify escaping of pattern and fix match_prev_cmd strategy"
This reverts commit 7f8ff2867c.
			
			
This commit is contained in:
		
							
								
								
									
										1
									
								
								Makefile
									
									
									
									
									
								
							
							
						
						
									
										1
									
								
								Makefile
									
									
									
									
									
								
							| @@ -3,6 +3,7 @@ SRC_DIR    := ./src | ||||
| SRC_FILES := \ | ||||
| 	$(SRC_DIR)/setup.zsh \ | ||||
| 	$(SRC_DIR)/config.zsh \ | ||||
| 	$(SRC_DIR)/util.zsh \ | ||||
| 	$(SRC_DIR)/features.zsh \ | ||||
| 	$(SRC_DIR)/bind.zsh \ | ||||
| 	$(SRC_DIR)/highlight.zsh \ | ||||
|   | ||||
| @@ -7,9 +7,19 @@ | ||||
| # | ||||
|  | ||||
| _zsh_autosuggest_strategy_default() { | ||||
| 	local prefix="$1" | ||||
| 	# Reset options to defaults and enable LOCAL_OPTIONS | ||||
| 	emulate -L zsh | ||||
|  | ||||
| 	# Enable globbing flags so that we can use (#m) | ||||
| 	setopt EXTENDED_GLOB | ||||
|  | ||||
| 	# Escape backslashes and all of the glob operators so we can use | ||||
| 	# this string as a pattern to search the $history associative array. | ||||
| 	# - (#m) globbing flag enables setting references for match data | ||||
| 	# TODO: Use (b) flag when we can drop support for zsh older than v5.0.8 | ||||
| 	local prefix="${1//(#m)[\\*?[\]<>()|^~#]/\\$MATCH}" | ||||
|  | ||||
| 	# Get the history items that match | ||||
| 	# - (r) subscript flag makes the pattern match on values | ||||
| 	typeset -g suggestion="${history[(r)${(b)prefix}*]}" | ||||
| 	typeset -g suggestion="${history[(r)${prefix}*]}" | ||||
| } | ||||
|   | ||||
| @@ -21,18 +21,19 @@ | ||||
| # `HIST_EXPIRE_DUPS_FIRST`. | ||||
|  | ||||
| _zsh_autosuggest_strategy_match_prev_cmd() { | ||||
| 	local prefix="$1" | ||||
| 	# TODO: Use (b) flag when we can drop support for zsh older than v5.0.8 | ||||
| 	local prefix="${1//(#m)[\\*?[\]<>()|^~#]/\\$MATCH}" | ||||
|  | ||||
| 	# Get all history event numbers that correspond to history | ||||
| 	# entries that match pattern $prefix* | ||||
| 	local history_match_keys | ||||
| 	history_match_keys=(${(k)history[(R)${(b)prefix}*]}) | ||||
| 	history_match_keys=(${(k)history[(R)$prefix*]}) | ||||
|  | ||||
| 	# By default we use the first history number (most recent history entry) | ||||
| 	local histkey="${history_match_keys[1]}" | ||||
|  | ||||
| 	# Get the previously executed command | ||||
| 	local prev_cmd="${history[$((HISTCMD-1))]}" | ||||
| 	local prev_cmd="$(_zsh_autosuggest_escape_command "${history[$((HISTCMD-1))]}")" | ||||
|  | ||||
| 	# Iterate up to the first 200 history event numbers that match $prefix | ||||
| 	for key in "${(@)history_match_keys[1,200]}"; do | ||||
|   | ||||
							
								
								
									
										11
									
								
								src/util.zsh
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										11
									
								
								src/util.zsh
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,11 @@ | ||||
|  | ||||
| #--------------------------------------------------------------------# | ||||
| # Utility Functions                                                  # | ||||
| #--------------------------------------------------------------------# | ||||
|  | ||||
| _zsh_autosuggest_escape_command() { | ||||
| 	setopt localoptions EXTENDED_GLOB | ||||
|  | ||||
| 	# Escape special chars in the string (requires EXTENDED_GLOB) | ||||
| 	echo -E "${1//(#m)[\"\'\\()\[\]|*?~]/\\$MATCH}" | ||||
| } | ||||
| @@ -101,6 +101,17 @@ ZSH_AUTOSUGGEST_BUFFER_MAX_SIZE= | ||||
| # Pty name for calculating autosuggestions asynchronously | ||||
| ZSH_AUTOSUGGEST_ASYNC_PTY_NAME=zsh_autosuggest_pty | ||||
|  | ||||
| #--------------------------------------------------------------------# | ||||
| # Utility Functions                                                  # | ||||
| #--------------------------------------------------------------------# | ||||
|  | ||||
| _zsh_autosuggest_escape_command() { | ||||
| 	setopt localoptions EXTENDED_GLOB | ||||
|  | ||||
| 	# Escape special chars in the string (requires EXTENDED_GLOB) | ||||
| 	echo -E "${1//(#m)[\"\'\\()\[\]|*?~]/\\$MATCH}" | ||||
| } | ||||
|  | ||||
| #--------------------------------------------------------------------# | ||||
| # Feature Detection                                                  # | ||||
| #--------------------------------------------------------------------# | ||||
| @@ -478,11 +489,21 @@ zle -N autosuggest-toggle _zsh_autosuggest_widget_toggle | ||||
| # | ||||
|  | ||||
| _zsh_autosuggest_strategy_default() { | ||||
| 	local prefix="$1" | ||||
| 	# Reset options to defaults and enable LOCAL_OPTIONS | ||||
| 	emulate -L zsh | ||||
|  | ||||
| 	# Enable globbing flags so that we can use (#m) | ||||
| 	setopt EXTENDED_GLOB | ||||
|  | ||||
| 	# Escape backslashes and all of the glob operators so we can use | ||||
| 	# this string as a pattern to search the $history associative array. | ||||
| 	# - (#m) globbing flag enables setting references for match data | ||||
| 	# TODO: Use (b) flag when we can drop support for zsh older than v5.0.8 | ||||
| 	local prefix="${1//(#m)[\\*?[\]<>()|^~#]/\\$MATCH}" | ||||
|  | ||||
| 	# Get the history items that match | ||||
| 	# - (r) subscript flag makes the pattern match on values | ||||
| 	typeset -g suggestion="${history[(r)${(b)prefix}*]}" | ||||
| 	typeset -g suggestion="${history[(r)${prefix}*]}" | ||||
| } | ||||
|  | ||||
| #--------------------------------------------------------------------# | ||||
| @@ -507,18 +528,19 @@ _zsh_autosuggest_strategy_default() { | ||||
| # `HIST_EXPIRE_DUPS_FIRST`. | ||||
|  | ||||
| _zsh_autosuggest_strategy_match_prev_cmd() { | ||||
| 	local prefix="$1" | ||||
| 	# TODO: Use (b) flag when we can drop support for zsh older than v5.0.8 | ||||
| 	local prefix="${1//(#m)[\\*?[\]<>()|^~#]/\\$MATCH}" | ||||
|  | ||||
| 	# Get all history event numbers that correspond to history | ||||
| 	# entries that match pattern $prefix* | ||||
| 	local history_match_keys | ||||
| 	history_match_keys=(${(k)history[(R)${(b)prefix}*]}) | ||||
| 	history_match_keys=(${(k)history[(R)$prefix*]}) | ||||
|  | ||||
| 	# By default we use the first history number (most recent history entry) | ||||
| 	local histkey="${history_match_keys[1]}" | ||||
|  | ||||
| 	# Get the previously executed command | ||||
| 	local prev_cmd="${history[$((HISTCMD-1))]}" | ||||
| 	local prev_cmd="$(_zsh_autosuggest_escape_command "${history[$((HISTCMD-1))]}")" | ||||
|  | ||||
| 	# Iterate up to the first 200 history event numbers that match $prefix | ||||
| 	for key in "${(@)history_match_keys[1,200]}"; do | ||||
|   | ||||
		Reference in New Issue
	
	Block a user