From: Vsevolod Stakhov Date: Fri, 29 Nov 2019 09:05:31 +0000 (+0000) Subject: [Minor] Fix asan friendliness in lpeg X-Git-Tag: 2.3~284 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=4e516ef44345e2f015572c83ba1bfb32f93c820a;p=thirdparty%2Frspamd.git [Minor] Fix asan friendliness in lpeg --- diff --git a/contrib/lua-lpeg/lpvm.c b/contrib/lua-lpeg/lpvm.c index 4ef4245793..6058bf5b1e 100644 --- a/contrib/lua-lpeg/lpvm.c +++ b/contrib/lua-lpeg/lpvm.c @@ -306,27 +306,39 @@ const char *match (lua_State *L, const char *o, const char *s, const char *e, continue; } case IChar: { - if ((byte)*s == p->i.aux && s < e) { p++; s++; } + if (s < e && (byte)*s == p->i.aux) { p++; s++; } else goto fail; continue; } case ITestChar: { - if ((byte)*s == p->i.aux && s < e) p += 2; + if (s < e && (byte)*s == p->i.aux) p += 2; else p += getoffset(p); continue; } case ISet: { - int c = (byte)*s; - if (testchar((p+1)->buff, c) && s < e) - { p += CHARSETINSTSIZE; s++; } - else goto fail; + if (s < e) { + int c = (byte) *s; + if (testchar((p + 1)->buff, c)) { + p += CHARSETINSTSIZE; + s++; + } + else goto fail; + } + else { + goto fail; + } continue; } case ITestSet: { - int c = (byte)*s; - if (testchar((p + 2)->buff, c) && s < e) - p += 1 + CHARSETINSTSIZE; - else p += getoffset(p); + if (s < e) { + int c = (byte) *s; + if (testchar((p + 2)->buff, c)) + p += 1 + CHARSETINSTSIZE; + else p += getoffset(p); + } + else { + p += getoffset(p); + } continue; } case IBehind: {