Change status_end_element_mismatch to point to closing tag name
Previously the error offset pointed to the first mismatching character, which can be confusing especially if the start tag name is a prefix of the end tag name. Instead, move the offset to the first character of the name - that way it should be more obvious that the problem is that the entire name mismatches. Fixes #112.
This commit is contained in:
parent
5ca7e7cffc
commit
1e23402eb2
2 changed files with 7 additions and 5 deletions
|
@ -3346,18 +3346,20 @@ PUGI__NS_BEGIN
|
|||
{
|
||||
++s;
|
||||
|
||||
mark = s;
|
||||
|
||||
char_t* name = cursor->name;
|
||||
if (!name) PUGI__THROW_ERROR(status_end_element_mismatch, s);
|
||||
if (!name) PUGI__THROW_ERROR(status_end_element_mismatch, mark);
|
||||
|
||||
while (PUGI__IS_CHARTYPE(*s, ct_symbol))
|
||||
{
|
||||
if (*s++ != *name++) PUGI__THROW_ERROR(status_end_element_mismatch, s);
|
||||
if (*s++ != *name++) PUGI__THROW_ERROR(status_end_element_mismatch, mark);
|
||||
}
|
||||
|
||||
if (*name)
|
||||
{
|
||||
if (*s == 0 && name[0] == endch && name[1] == 0) PUGI__THROW_ERROR(status_bad_end_element, s);
|
||||
else PUGI__THROW_ERROR(status_end_element_mismatch, s);
|
||||
else PUGI__THROW_ERROR(status_end_element_mismatch, mark);
|
||||
}
|
||||
|
||||
PUGI__POPNODE(); // Pop.
|
||||
|
|
|
@ -1005,8 +1005,8 @@ TEST(parse_error_offset)
|
|||
CHECK_OFFSET("<n></n $>", parse_default, status_bad_end_element, 7);
|
||||
CHECK_OFFSET("<n></n", parse_default, status_bad_end_element, 5);
|
||||
|
||||
CHECK_OFFSET("<no></na>", parse_default, status_end_element_mismatch, 8);
|
||||
CHECK_OFFSET("<no></nod>", parse_default, status_end_element_mismatch, 9);
|
||||
CHECK_OFFSET("<no></na>", parse_default, status_end_element_mismatch, 6);
|
||||
CHECK_OFFSET("<no></nod>", parse_default, status_end_element_mismatch, 6);
|
||||
}
|
||||
|
||||
TEST(parse_result_default)
|
||||
|
|
Loading…
Add table
Reference in a new issue