mirror of
https://github.com/profanity-im/profanity.git
synced 2024-12-04 14:46:46 -05:00
Merge branch 'master' into windows
This commit is contained in:
commit
133614d749
@ -210,7 +210,7 @@ parse_args_with_freetext(const char * const inp, int min, int max)
|
|||||||
} else {
|
} else {
|
||||||
in_token = TRUE;
|
in_token = TRUE;
|
||||||
num_tokens++;
|
num_tokens++;
|
||||||
if (num_tokens == max + 1) {
|
if ((num_tokens == max + 1) && (curr_uni != '"')) {
|
||||||
in_freetext = TRUE;
|
in_freetext = TRUE;
|
||||||
} else if (curr_uni == '"') {
|
} else if (curr_uni == '"') {
|
||||||
in_quotes = TRUE;
|
in_quotes = TRUE;
|
||||||
|
@ -292,6 +292,42 @@ parse_cmd_with_quoted_freetext(void)
|
|||||||
g_strfreev(result);
|
g_strfreev(result);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
parse_cmd_with_third_arg_quoted_0_min_3_max(void)
|
||||||
|
{
|
||||||
|
char *inp = "/group add friends \"The User\"";
|
||||||
|
gchar **result = parse_args_with_freetext(inp, 0, 3);
|
||||||
|
|
||||||
|
assert_int_equals(3, g_strv_length(result));
|
||||||
|
assert_string_equals("add", result[0]);
|
||||||
|
assert_string_equals("friends", result[1]);
|
||||||
|
assert_string_equals("The User", result[2]);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
parse_cmd_with_second_arg_quoted_0_min_3_max(void)
|
||||||
|
{
|
||||||
|
char *inp = "/group add \"The Group\" friend";
|
||||||
|
gchar **result = parse_args_with_freetext(inp, 0, 3);
|
||||||
|
|
||||||
|
assert_int_equals(3, g_strv_length(result));
|
||||||
|
assert_string_equals("add", result[0]);
|
||||||
|
assert_string_equals("The Group", result[1]);
|
||||||
|
assert_string_equals("friend", result[2]);
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
parse_cmd_with_second_and_third_arg_quoted_0_min_3_max(void)
|
||||||
|
{
|
||||||
|
char *inp = "/group add \"The Group\" \"The User\"";
|
||||||
|
gchar **result = parse_args_with_freetext(inp, 0, 3);
|
||||||
|
|
||||||
|
assert_int_equals(3, g_strv_length(result));
|
||||||
|
assert_string_equals("add", result[0]);
|
||||||
|
assert_string_equals("The Group", result[1]);
|
||||||
|
assert_string_equals("The User", result[2]);
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
count_one_token(void)
|
count_one_token(void)
|
||||||
{
|
{
|
||||||
@ -451,4 +487,7 @@ register_parser_tests(void)
|
|||||||
TEST(get_first_two_of_three_first_quoted);
|
TEST(get_first_two_of_three_first_quoted);
|
||||||
TEST(get_first_two_of_three_second_quoted);
|
TEST(get_first_two_of_three_second_quoted);
|
||||||
TEST(get_first_two_of_three_first_and_second_quoted);
|
TEST(get_first_two_of_three_first_and_second_quoted);
|
||||||
|
TEST(parse_cmd_with_third_arg_quoted_0_min_3_max);
|
||||||
|
TEST(parse_cmd_with_second_arg_quoted_0_min_3_max);
|
||||||
|
TEST(parse_cmd_with_second_and_third_arg_quoted_0_min_3_max);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user