mirror of
				https://github.com/sharkdp/bat.git
				synced 2025-10-26 04:33:53 +00:00 
			
		
		
		
	Improve bash completion escaping
`compopt -o filenames` is a cheap way to accomplish mostly wanted behavior. However it is semantically incorrect when we are not actually completing filenames, and has side effects -- for example adds a trailing slash to candidates matching present dirs. bash >= 4.1 can `printf -v` to an array index, use it instead where available.
This commit is contained in:
		
				
					committed by
					
						 David Peter
						David Peter
					
				
			
			
				
	
			
			
			
						parent
						
							66edfe5dff
						
					
				
				
					commit
					2dbc88d3af
				
			
							
								
								
									
										25
									
								
								assets/completions/bat.bash.in
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										25
									
								
								assets/completions/bat.bash.in
									
									
									
									
										vendored
									
									
								
							| @@ -10,6 +10,27 @@ __bat_init_completion() | |||||||
| 	_get_comp_words_by_ref "$@" cur prev words cword | 	_get_comp_words_by_ref "$@" cur prev words cword | ||||||
| } | } | ||||||
|  |  | ||||||
|  | __bat_escape_completions() | ||||||
|  | { | ||||||
|  | 	# Do not escape if completing a quoted value. | ||||||
|  | 	[[ $cur == [\"\']* ]] && return 0 | ||||||
|  | 	# printf -v to an array index is available in bash >= 4.1. | ||||||
|  | 	# Use it if available, as -o filenames is semantically incorrect if | ||||||
|  | 	# we are not actually completing filenames, and it has side effects | ||||||
|  | 	# (e.g. adds trailing slash to candidates matching present dirs). | ||||||
|  | 	if (( | ||||||
|  | 		BASH_VERSINFO[0] > 4 || \ | ||||||
|  | 		BASH_VERSINFO[0] == 4 && BASH_VERSINFO[1] > 0 | ||||||
|  | 	)); then | ||||||
|  | 		local i | ||||||
|  | 		for i in ${!COMPREPLY[*]}; do | ||||||
|  | 			printf -v "COMPREPLY[i]" %q "${COMPREPLY[i]}" | ||||||
|  | 		done | ||||||
|  | 	else | ||||||
|  | 		compopt -o filenames | ||||||
|  | 	fi | ||||||
|  | } | ||||||
|  |  | ||||||
| _bat() { | _bat() { | ||||||
| 	local cur prev words cword split=false | 	local cur prev words cword split=false | ||||||
| 	if declare -F _init_completion >/dev/null 2>&1; then | 	if declare -F _init_completion >/dev/null 2>&1; then | ||||||
| @@ -45,7 +66,7 @@ _bat() { | |||||||
| 				printf "%s\n" "$lang" | 				printf "%s\n" "$lang" | ||||||
| 			done | 			done | ||||||
| 		)" -- "$cur")) | 		)" -- "$cur")) | ||||||
| 		compopt -o filenames  # for escaping |                 __bat_escape_completions | ||||||
| 		return 0 | 		return 0 | ||||||
| 		;; | 		;; | ||||||
| 	-H | --highlight-line | \ | 	-H | --highlight-line | \ | ||||||
| @@ -92,7 +113,7 @@ _bat() { | |||||||
| 	--theme) | 	--theme) | ||||||
| 		local IFS=$'\n' | 		local IFS=$'\n' | ||||||
| 		COMPREPLY=($(compgen -W "$("$1" --list-themes)" -- "$cur")) | 		COMPREPLY=($(compgen -W "$("$1" --list-themes)" -- "$cur")) | ||||||
| 		compopt -o filenames  # for escaping |                 __bat_escape_completions | ||||||
| 		return 0 | 		return 0 | ||||||
| 		;; | 		;; | ||||||
| 	--style) | 	--style) | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user