mirror of
https://github.com/profanity-im/profanity.git
synced 2024-10-27 20:30:13 -04:00
Command parser handles quotes arguments
This commit is contained in:
parent
f5711001f7
commit
bae9bde484
33
src/parser.c
33
src/parser.c
@ -60,6 +60,7 @@ parse_args(const char * const inp, int min, int max)
|
|||||||
|
|
||||||
int inp_size = strlen(copy);
|
int inp_size = strlen(copy);
|
||||||
gboolean in_token = FALSE;
|
gboolean in_token = FALSE;
|
||||||
|
gboolean in_quotes = FALSE;
|
||||||
char *token_start = ©[0];
|
char *token_start = ©[0];
|
||||||
int token_size = 0;
|
int token_size = 0;
|
||||||
GSList *tokens = NULL;
|
GSList *tokens = NULL;
|
||||||
@ -72,9 +73,24 @@ parse_args(const char * const inp, int min, int max)
|
|||||||
continue;
|
continue;
|
||||||
} else {
|
} else {
|
||||||
in_token = TRUE;
|
in_token = TRUE;
|
||||||
|
if (copy[i] == '"') {
|
||||||
|
in_quotes = TRUE;
|
||||||
|
i++;
|
||||||
|
}
|
||||||
token_start = ©[i];
|
token_start = ©[i];
|
||||||
token_size++;
|
token_size++;
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
if (in_quotes) {
|
||||||
|
if ((copy[i] == '\0') || (copy[i] == '"')) {
|
||||||
|
tokens = g_slist_append(tokens, g_strndup(token_start,
|
||||||
|
token_size));
|
||||||
|
token_size = 0;
|
||||||
|
in_token = FALSE;
|
||||||
|
in_quotes = FALSE;
|
||||||
|
} else {
|
||||||
|
token_size++;
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
if (copy[i] == ' ' || copy[i] == '\0') {
|
if (copy[i] == ' ' || copy[i] == '\0') {
|
||||||
tokens = g_slist_append(tokens, g_strndup(token_start,
|
tokens = g_slist_append(tokens, g_strndup(token_start,
|
||||||
@ -86,6 +102,7 @@ parse_args(const char * const inp, int min, int max)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
int num = g_slist_length(tokens) - 1;
|
int num = g_slist_length(tokens) - 1;
|
||||||
|
|
||||||
@ -163,6 +180,7 @@ parse_args_with_freetext(const char * const inp, int min, int max)
|
|||||||
int inp_size = strlen(copy);
|
int inp_size = strlen(copy);
|
||||||
gboolean in_token = FALSE;
|
gboolean in_token = FALSE;
|
||||||
gboolean in_freetext = FALSE;
|
gboolean in_freetext = FALSE;
|
||||||
|
gboolean in_quotes = FALSE;
|
||||||
char *token_start = ©[0];
|
char *token_start = ©[0];
|
||||||
int token_size = 0;
|
int token_size = 0;
|
||||||
int num_tokens = 0;
|
int num_tokens = 0;
|
||||||
@ -179,10 +197,24 @@ parse_args_with_freetext(const char * const inp, int min, int max)
|
|||||||
num_tokens++;
|
num_tokens++;
|
||||||
if (num_tokens == max + 1) {
|
if (num_tokens == max + 1) {
|
||||||
in_freetext = TRUE;
|
in_freetext = TRUE;
|
||||||
|
} else if (copy[i] == '"') {
|
||||||
|
in_quotes = TRUE;
|
||||||
|
i++;
|
||||||
}
|
}
|
||||||
token_start = ©[i];
|
token_start = ©[i];
|
||||||
token_size++;
|
token_size++;
|
||||||
}
|
}
|
||||||
|
} else {
|
||||||
|
if (in_quotes) {
|
||||||
|
if ((copy[i] == '\0') || (copy[i] == '"')) {
|
||||||
|
tokens = g_slist_append(tokens, g_strndup(token_start,
|
||||||
|
token_size));
|
||||||
|
token_size = 0;
|
||||||
|
in_token = FALSE;
|
||||||
|
in_quotes = FALSE;
|
||||||
|
} else {
|
||||||
|
token_size++;
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
if ((!in_freetext && copy[i] == ' ') || copy[i] == '\0') {
|
if ((!in_freetext && copy[i] == ' ') || copy[i] == '\0') {
|
||||||
tokens = g_slist_append(tokens, g_strndup(token_start,
|
tokens = g_slist_append(tokens, g_strndup(token_start,
|
||||||
@ -194,6 +226,7 @@ parse_args_with_freetext(const char * const inp, int min, int max)
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
int num = g_slist_length(tokens) - 1;
|
int num = g_slist_length(tokens) - 1;
|
||||||
|
|
||||||
|
@ -180,6 +180,105 @@ parse_cmd_min_zero_with_freetext(void)
|
|||||||
g_strfreev(result);
|
g_strfreev(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
parse_cmd_with_quoted(void)
|
||||||
|
{
|
||||||
|
char *inp = "/cmd \"arg1\" arg2";
|
||||||
|
gchar **result = parse_args(inp, 2, 2);
|
||||||
|
|
||||||
|
assert_int_equals(2, g_strv_length(result));
|
||||||
|
assert_string_equals("arg1", result[0]);
|
||||||
|
assert_string_equals("arg2", result[1]);
|
||||||
|
g_strfreev(result);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
parse_cmd_with_quoted_and_space(void)
|
||||||
|
{
|
||||||
|
char *inp = "/cmd \"the arg1\" arg2";
|
||||||
|
gchar **result = parse_args(inp, 2, 2);
|
||||||
|
|
||||||
|
assert_int_equals(2, g_strv_length(result));
|
||||||
|
assert_string_equals("the arg1", result[0]);
|
||||||
|
assert_string_equals("arg2", result[1]);
|
||||||
|
g_strfreev(result);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
parse_cmd_with_quoted_and_many_spaces(void)
|
||||||
|
{
|
||||||
|
char *inp = "/cmd \"the arg1 is here\" arg2";
|
||||||
|
gchar **result = parse_args(inp, 2, 2);
|
||||||
|
|
||||||
|
assert_int_equals(2, g_strv_length(result));
|
||||||
|
assert_string_equals("the arg1 is here", result[0]);
|
||||||
|
assert_string_equals("arg2", result[1]);
|
||||||
|
g_strfreev(result);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
parse_cmd_with_many_quoted_and_many_spaces(void)
|
||||||
|
{
|
||||||
|
char *inp = "/cmd \"the arg1 is here\" \"and arg2 is right here\"";
|
||||||
|
gchar **result = parse_args(inp, 2, 2);
|
||||||
|
|
||||||
|
assert_int_equals(2, g_strv_length(result));
|
||||||
|
assert_string_equals("the arg1 is here", result[0]);
|
||||||
|
assert_string_equals("and arg2 is right here", result[1]);
|
||||||
|
g_strfreev(result);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
parse_cmd_freetext_with_quoted(void)
|
||||||
|
{
|
||||||
|
char *inp = "/cmd \"arg1\" arg2 hello there whats up";
|
||||||
|
gchar **result = parse_args_with_freetext(inp, 3, 3);
|
||||||
|
|
||||||
|
assert_int_equals(3, g_strv_length(result));
|
||||||
|
assert_string_equals("arg1", result[0]);
|
||||||
|
assert_string_equals("arg2", result[1]);
|
||||||
|
assert_string_equals("hello there whats up", result[2]);
|
||||||
|
g_strfreev(result);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
parse_cmd_freetext_with_quoted_and_space(void)
|
||||||
|
{
|
||||||
|
char *inp = "/cmd \"the arg1\" arg2 another bit of freetext";
|
||||||
|
gchar **result = parse_args_with_freetext(inp, 3, 3);
|
||||||
|
|
||||||
|
assert_int_equals(3, g_strv_length(result));
|
||||||
|
assert_string_equals("the arg1", result[0]);
|
||||||
|
assert_string_equals("arg2", result[1]);
|
||||||
|
assert_string_equals("another bit of freetext", result[2]);
|
||||||
|
g_strfreev(result);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
parse_cmd_freetext_with_quoted_and_many_spaces(void)
|
||||||
|
{
|
||||||
|
char *inp = "/cmd \"the arg1 is here\" arg2 some more freetext";
|
||||||
|
gchar **result = parse_args_with_freetext(inp, 3, 3);
|
||||||
|
|
||||||
|
assert_int_equals(3, g_strv_length(result));
|
||||||
|
assert_string_equals("the arg1 is here", result[0]);
|
||||||
|
assert_string_equals("arg2", result[1]);
|
||||||
|
assert_string_equals("some more freetext", result[2]);
|
||||||
|
g_strfreev(result);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
parse_cmd_freetext_with_many_quoted_and_many_spaces(void)
|
||||||
|
{
|
||||||
|
char *inp = "/cmd \"the arg1 is here\" \"and arg2 is right here\" and heres the free text";
|
||||||
|
gchar **result = parse_args_with_freetext(inp, 3, 3);
|
||||||
|
|
||||||
|
assert_int_equals(3, g_strv_length(result));
|
||||||
|
assert_string_equals("the arg1 is here", result[0]);
|
||||||
|
assert_string_equals("and arg2 is right here", result[1]);
|
||||||
|
assert_string_equals("and heres the free text", result[2]);
|
||||||
|
g_strfreev(result);
|
||||||
|
}
|
||||||
void
|
void
|
||||||
register_parser_tests(void)
|
register_parser_tests(void)
|
||||||
{
|
{
|
||||||
@ -200,4 +299,12 @@ register_parser_tests(void)
|
|||||||
TEST(parse_cmd_with_too_many_returns_null);
|
TEST(parse_cmd_with_too_many_returns_null);
|
||||||
TEST(parse_cmd_min_zero);
|
TEST(parse_cmd_min_zero);
|
||||||
TEST(parse_cmd_min_zero_with_freetext);
|
TEST(parse_cmd_min_zero_with_freetext);
|
||||||
|
TEST(parse_cmd_with_quoted);
|
||||||
|
TEST(parse_cmd_with_quoted_and_space);
|
||||||
|
TEST(parse_cmd_with_quoted_and_many_spaces);
|
||||||
|
TEST(parse_cmd_with_many_quoted_and_many_spaces);
|
||||||
|
TEST(parse_cmd_freetext_with_quoted);
|
||||||
|
TEST(parse_cmd_freetext_with_quoted_and_space);
|
||||||
|
TEST(parse_cmd_freetext_with_quoted_and_many_spaces);
|
||||||
|
TEST(parse_cmd_freetext_with_many_quoted_and_many_spaces);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user