Mercurial > public > mercurial-scm > hg-stable
diff mercurial/parsers.c @ 27226:f5e8cb813a4d stable
parsers: fix parse_dirstate to check len before unpacking header (issue4979)
author | Yuya Nishihara <yuya@tcha.org> |
---|---|
date | Wed, 02 Dec 2015 23:04:58 +0900 |
parents | ce03e72837c6 |
children | 5042b999ef0a |
line wrap: on
line diff
--- a/mercurial/parsers.c Tue Dec 01 20:18:28 2015 -0600 +++ b/mercurial/parsers.c Wed Dec 02 23:04:58 2015 +0900 @@ -493,6 +493,11 @@ /* read filenames */ while (pos >= 40 && pos < len) { + if (pos + 17 > len) { + PyErr_SetString(PyExc_ValueError, + "overflow in dirstate"); + goto quit; + } cur = str + pos; /* unpack header */ state = *cur;