degesch: add & use strncasecmp_ascii()
This commit is contained in:
parent
a6782e5e60
commit
897bb00af1
11
common.c
11
common.c
@ -70,6 +70,17 @@ str_vector_find (const struct str_vector *v, const char *s)
|
||||
return -1;
|
||||
}
|
||||
|
||||
static int
|
||||
strncasecmp_ascii (const char *a, const char *b, size_t n)
|
||||
{
|
||||
int x;
|
||||
while (n-- && (*a || *b))
|
||||
if ((x = tolower_ascii (*(const unsigned char *) a++)
|
||||
- tolower_ascii (*(const unsigned char *) b++)))
|
||||
return x;
|
||||
return 0;
|
||||
}
|
||||
|
||||
// --- Logging -----------------------------------------------------------------
|
||||
|
||||
static void
|
||||
|
@ -6388,11 +6388,11 @@ complete_command (struct app_context *ctx, struct completion *data,
|
||||
prefix = "/";
|
||||
}
|
||||
|
||||
size_t word_len = strlen (word);
|
||||
for (size_t i = 0; i < N_ELEMENTS (g_command_handlers); i++)
|
||||
{
|
||||
struct command_handler *handler = &g_command_handlers[i];
|
||||
// FIXME: we want an ASCII version
|
||||
if (!strncasecmp (word, handler->name, strlen (word)))
|
||||
if (!strncasecmp_ascii (word, handler->name, word_len))
|
||||
str_vector_add_owned (output,
|
||||
xstrdup_printf ("%s%s", prefix, handler->name));
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user