libedit: Reduce surprising behaviour with filename completion some more:
* Quote '*', '?' and '['. While it may be more useful to expand them to matching pathnames, this at least matches with the completion we do. * '@' is a regular character for filenames. Some other shells do @<hostname> completion but we do not. * Prefix names starting with '-' and '+' with './' so they are not seen as options.
This commit is contained in:
parent
8b1f99cdd4
commit
196ff96e78
@ -50,10 +50,10 @@ __FBSDID("$FreeBSD$");
|
||||
#include "histedit.h"
|
||||
#include "filecomplete.h"
|
||||
|
||||
static char break_chars[] = { ' ', '\t', '\n', '"', '\\', '\'', '`', '@',
|
||||
'$', '>', '<', '=', ';', '|', '&', '{', '(', '\0' };
|
||||
static char break_chars[] = { ' ', '\t', '\n', '"', '\\', '\'', '`',
|
||||
'>', '<', '=', ';', '|', '&', '{', '(', '\0' };
|
||||
/* Tilde is deliberately omitted here, we treat it specially. */
|
||||
static char extra_quote_chars[] = { ')', '}', '\0' };
|
||||
static char extra_quote_chars[] = { ')', '}', '*', '?', '[', '$', '\0' };
|
||||
|
||||
|
||||
/********************************/
|
||||
@ -595,6 +595,8 @@ sh_quote(const char *str)
|
||||
int extra_len = 0;
|
||||
char *quoted_str, *dst;
|
||||
|
||||
if (*str == '-' || *str == '+')
|
||||
extra_len += 2;
|
||||
for (src = str; *src != '\0'; src++)
|
||||
if (strchr(break_chars, *src) ||
|
||||
strchr(extra_quote_chars, *src))
|
||||
@ -606,6 +608,8 @@ sh_quote(const char *str)
|
||||
return NULL;
|
||||
|
||||
dst = quoted_str;
|
||||
if (*str == '-' || *str == '+')
|
||||
*dst++ = '.', *dst++ = '/';
|
||||
for (src = str; *src != '\0'; src++) {
|
||||
if (strchr(break_chars, *src) ||
|
||||
strchr(extra_quote_chars, *src))
|
||||
|
Loading…
x
Reference in New Issue
Block a user