# HG changeset patch # User Yuya Nishihara # Date 2015-04-29 14:07:34 # Node ID b3142ea2a0d495fce385493dc0af5696d193d4b0 # Parent e530cde6d115f4e97da783444a8ab722421c67e1 parsers: avoid signed integer overflow in calculation of leaf-node index If v = -INT_MAX - 1, -v would exceed INT_MAX. I don't think this would cause problems such as issue4627, but we can't blame it as a compiler bug because signed integer overflow is undefined in C. diff --git a/mercurial/parsers.c b/mercurial/parsers.c --- a/mercurial/parsers.c +++ b/mercurial/parsers.c @@ -1312,7 +1312,7 @@ static int nt_find(indexObject *self, co const char *n; Py_ssize_t i; - v = -v - 1; + v = -(v + 1); n = index_node(self, v); if (n == NULL) return -2; @@ -1368,7 +1368,7 @@ static int nt_insert(indexObject *self, return 0; } if (v < 0) { - const char *oldnode = index_node(self, -v - 1); + const char *oldnode = index_node(self, -(v + 1)); int noff; if (!oldnode || !memcmp(oldnode, node, 20)) {