Implement special character escaping
This commit is contained in:
parent
a9b8e24007
commit
da0175105d
@ -15,6 +15,7 @@ static bool is_special(char c)
|
|||||||
switch (c) {
|
switch (c) {
|
||||||
case '|':
|
case '|':
|
||||||
case '.':
|
case '.':
|
||||||
|
case '\\':
|
||||||
return true;
|
return true;
|
||||||
default:
|
default:
|
||||||
return false;
|
return false;
|
||||||
@ -26,6 +27,9 @@ static int parse_literal(const char *input, int rem, char *out)
|
|||||||
if (rem > 0 && !is_special(input[0])) {
|
if (rem > 0 && !is_special(input[0])) {
|
||||||
*out = input[0];
|
*out = input[0];
|
||||||
return 1;
|
return 1;
|
||||||
|
} else if (rem > 1 && '\\' == input[0]) {
|
||||||
|
*out = input[1];
|
||||||
|
return 2;
|
||||||
} else {
|
} else {
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
@ -97,6 +97,34 @@ static void dot_is_parsed_as_unquantified_wildcard_term(void)
|
|||||||
regex_free_children(&r);
|
regex_free_children(&r);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void backslash_dot_is_parsed_as_unquantified_literal(void)
|
||||||
|
{
|
||||||
|
regex_t r = { 0 };
|
||||||
|
const int result = PARSE_REGEX_STRING("\\.", &r);
|
||||||
|
ASSERT_NE(-1, result);
|
||||||
|
|
||||||
|
ASSERT_EQ(1, r.sequence.len);
|
||||||
|
ASSERT_EQ(QUANTIFIER_NONE, r.sequence.contents[0].quantifier);
|
||||||
|
ASSERT_EQ(TERM_TYPE_LITERAL, r.sequence.contents[0].type);
|
||||||
|
ASSERT_EQ('.', r.sequence.contents[0].literal);
|
||||||
|
|
||||||
|
regex_free_children(&r);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void backslash_backslash_is_parsed_as_unquantified_literal(void)
|
||||||
|
{
|
||||||
|
regex_t r = { 0 };
|
||||||
|
const int result = PARSE_REGEX_STRING("\\\\", &r);
|
||||||
|
ASSERT_NE(-1, result);
|
||||||
|
|
||||||
|
ASSERT_EQ(1, r.sequence.len);
|
||||||
|
ASSERT_EQ(QUANTIFIER_NONE, r.sequence.contents[0].quantifier);
|
||||||
|
ASSERT_EQ(TERM_TYPE_LITERAL, r.sequence.contents[0].type);
|
||||||
|
ASSERT_EQ('\\', r.sequence.contents[0].literal);
|
||||||
|
|
||||||
|
regex_free_children(&r);
|
||||||
|
}
|
||||||
|
|
||||||
int main(void)
|
int main(void)
|
||||||
{
|
{
|
||||||
TESTING_BEGIN();
|
TESTING_BEGIN();
|
||||||
@ -107,5 +135,7 @@ int main(void)
|
|||||||
b_is_parsed_as_unquantified_literal();
|
b_is_parsed_as_unquantified_literal();
|
||||||
abc_is_parsed_as_sequence_of_unquantified_literals();
|
abc_is_parsed_as_sequence_of_unquantified_literals();
|
||||||
dot_is_parsed_as_unquantified_wildcard_term();
|
dot_is_parsed_as_unquantified_wildcard_term();
|
||||||
|
backslash_dot_is_parsed_as_unquantified_literal();
|
||||||
|
backslash_backslash_is_parsed_as_unquantified_literal();
|
||||||
return TESTING_END();
|
return TESTING_END();
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user