1
1
mirror of https://github.com/profanity-im/profanity.git synced 2025-01-03 14:57:42 -05:00

Improve cmd argument parser

"" used to become " now it just becomes an empty argument.
Also if quotes appeared after a token started then if the number of
quotes in the token is n the resulting one would be a token with the
n last characters cut off, now it's fixed.

Fixes https://github.com/profanity-im/profanity/issues/497
This commit is contained in:
MarcoPolo-PasTonMolo 2022-06-16 21:07:15 +03:00
parent 7cb045fce7
commit 13f1b831df

View File

@ -83,8 +83,17 @@ _parse_args_helper(const char* const inp, int min, int max, gboolean* result, gb
i++; i++;
gchar* next_ch = g_utf8_next_char(curr_ch); gchar* next_ch = g_utf8_next_char(curr_ch);
gunichar next_uni = g_utf8_get_char(next_ch); gunichar next_uni = g_utf8_get_char(next_ch);
token_start = next_ch;
token_size += g_unichar_to_utf8(next_uni, NULL); if (next_uni == '"') {
tokens = g_slist_append(tokens, g_strndup(curr_ch,
0));
token_size = 0;
in_token = FALSE;
in_quotes = FALSE;
} else {
token_start = next_ch;
token_size += g_unichar_to_utf8(next_uni, NULL);
}
} }
if (curr_uni == '"') { if (curr_uni == '"') {
gchar* next_ch = g_utf8_next_char(curr_ch); gchar* next_ch = g_utf8_next_char(curr_ch);
@ -115,7 +124,7 @@ _parse_args_helper(const char* const inp, int min, int max, gboolean* result, gb
token_size)); token_size));
token_size = 0; token_size = 0;
in_token = FALSE; in_token = FALSE;
} else if (curr_uni != '"') { } else {
token_size += g_unichar_to_utf8(curr_uni, NULL); token_size += g_unichar_to_utf8(curr_uni, NULL);
} }
} }