Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
6 changes: 5 additions & 1 deletion babel/messages/pofile.py
Original file line number Diff line number Diff line change
Expand Up @@ -276,7 +276,11 @@ def _process_keyword_line(self, lineno, line, obsolete=False) -> None:
self.in_msgid = False
self.in_msgstr = True
kwarg, has_bracket, idxarg = keyword.partition('[')
idx = int(idxarg[:-1]) if has_bracket else 0
try:
idx = int(idxarg[:-1]) if has_bracket else 0
except ValueError:
self._invalid_pofile(line, lineno, f"Invalid plural index in keyword {keyword!r}")
return
s = _NormalizedString(arg) if arg != '""' else _NormalizedString()
self.translations.append([idx, s])
return
Expand Down
14 changes: 14 additions & 0 deletions tests/messages/test_pofile.py
Original file line number Diff line number Diff line change
Expand Up @@ -160,3 +160,17 @@ def test_issue_1134(case: str, abort_invalid: bool):
output = pofile.read_po(buf)
assert len(output) == 1
assert output["foo"].string in ((''), ('', ''))


@pytest.mark.parametrize("abort_invalid", [False, True])
def test_invalid_msgstr_index_issue_1209(abort_invalid: bool):
# Regression test for #1209: a non-integer plural index in msgstr[...] must be reported
# through the normal invalid-pofile handling, not leak a bare ValueError from int().
buf = StringIO('msgstr[\x0c]')

if abort_invalid:
with pytest.raises(pofile.PoFileError):
pofile.read_po(buf, abort_invalid=True)
else:
# No crash: an invalid entry is skipped with a warning.
pofile.read_po(buf)