Fix for buffer overflows identified by libgmalloc

This commit is contained in:
ridiculousfish 2013-10-16 01:02:15 -07:00
parent 4980959fce
commit 3c5d5b344e
2 changed files with 18 additions and 10 deletions

View file

@ -1503,14 +1503,20 @@ static int mk_wcwidth(wchar_t ucs)
static int mk_wcswidth(const wchar_t *pwcs, size_t n) static int mk_wcswidth(const wchar_t *pwcs, size_t n)
{ {
int w, width = 0; int width = 0;
for (size_t i=0; i < n; i++)
for (; *pwcs && n-- > 0; pwcs++) {
if ((w = mk_wcwidth(*pwcs)) < 0) if (pwcs[i] == L'\0')
return -1; break;
else
width += w; int w = mk_wcwidth(pwcs[i]);
if (w < 0)
{
width = -1;
break;
}
width += w;
}
return width; return width;
} }

View file

@ -260,8 +260,7 @@ void parse_util_cmdsubst_extent(const wchar_t *buff, size_t cursor_pos, const wc
/* No subshell found, all done */ /* No subshell found, all done */
break; break;
} }
/* Interpret NULL to mean the end */
/* Intrepret NULL to mean the end */
if (end == NULL) if (end == NULL)
{ {
end = const_cast<wchar_t *>(buff) + bufflen; end = const_cast<wchar_t *>(buff) + bufflen;
@ -273,6 +272,9 @@ void parse_util_cmdsubst_extent(const wchar_t *buff, size_t cursor_pos, const wc
begin++; begin++;
ap = begin; ap = begin;
bp = end; bp = end;
/* pos is where to begin looking for the next one. But if we reached the end there's no next one. */
if (begin >= end)
break;
pos = begin + 1; pos = begin + 1;
} }
else if (begin >= cursor) else if (begin >= cursor)