patch 9.1.0762: 'cedit', 'termwinkey' and 'wildchar' may not be parsed correctly
Problem:  'cedit', 'termwinkey' and 'wildchar' may not be parsed
          correctly
Solution: improve string_to_key() function in option.c
          (Milly)
- Problem: `^@` raises an error.
  Solution: Store as `<Nul>`.
- Problem: `<t_xx` does not raise an error.
  Solution: Raise an error if closing `>` is missing.
- Problem: Single `<` or `^` raises an error. It is inconvenient for users.
  Solution: They are stored as a single character.
closes: #15811
Signed-off-by: Milly <milly.ca@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
			
			
This commit is contained in:
		
				
					committed by
					
						 Christian Brabandt
						Christian Brabandt
					
				
			
			
				
	
			
			
			
						parent
						
							1a31c430bb
						
					
				
				
					commit
					a9c6f90918
				
			
							
								
								
									
										18
									
								
								src/option.c
									
									
									
									
									
								
							
							
						
						
									
										18
									
								
								src/option.c
									
									
									
									
									
								
							| @ -2794,16 +2794,21 @@ did_set_option( | ||||
|  | ||||
| /* | ||||
|  * Convert a key name or string into a key value. | ||||
|  * Used for 'wildchar' and 'cedit' options. | ||||
|  * Used for 'cedit', 'termwinkey', 'wildchar' and 'wildcharm' options. | ||||
|  * When "multi_byte" is TRUE allow for multi-byte characters. | ||||
|  */ | ||||
|     int | ||||
| string_to_key(char_u *arg, int multi_byte) | ||||
| { | ||||
|     if (*arg == '<') | ||||
|     if (*arg == '<' && arg[1]) | ||||
| 	return find_key_option(arg + 1, TRUE); | ||||
|     if (*arg == '^') | ||||
| 	return Ctrl_chr(arg[1]); | ||||
|     if (*arg == '^' && arg[1]) | ||||
|     { | ||||
| 	int key = Ctrl_chr(arg[1]); | ||||
| 	if (key == 0)		// ^@ is <Nul> | ||||
| 	    key = K_ZERO; | ||||
| 	return key; | ||||
|     } | ||||
|     if (multi_byte) | ||||
| 	return PTR2CHAR(arg); | ||||
|     return *arg; | ||||
| @ -5622,7 +5627,10 @@ find_key_option(char_u *arg_arg, int has_lt) | ||||
|     // Don't use get_special_key_code() for t_xx, we don't want it to call | ||||
|     // add_termcap_entry(). | ||||
|     if (arg[0] == 't' && arg[1] == '_' && arg[2] && arg[3]) | ||||
| 	key = TERMCAP2KEY(arg[2], arg[3]); | ||||
|     { | ||||
| 	if (!has_lt || arg[4] == '>') | ||||
| 	    key = TERMCAP2KEY(arg[2], arg[3]); | ||||
|     } | ||||
|     else if (has_lt) | ||||
|     { | ||||
| 	--arg;			    // put arg at the '<' | ||||
|  | ||||
		Reference in New Issue
	
	Block a user