From: Arun Prakash Jana Date: Thu, 13 Jun 2019 00:37:53 +0000 (+0530) Subject: Fix warning on CentOS 6 (refer to #282) X-Git-Tag: v2.6~102 X-Git-Url: http://www.git.stargrave.org/?a=commitdiff_plain;h=dba87bfdbec8435400b2729fa4e653fa5b7bba5a;p=nnn.git Fix warning on CentOS 6 (refer to #282) --- diff --git a/src/nnn.c b/src/nnn.c index 09826f7e..db57b618 100644 --- a/src/nnn.c +++ b/src/nnn.c @@ -1756,14 +1756,17 @@ static char *xreadline(char *prefill, char *prompt) size_t len, pos; int x, y, r; wint_t ch[2] = {0}; - wchar_t * const buf = (wchar_t *)g_buf; + wchar_t * const buf = malloc(sizeof(wchar_t) * CMD_LEN_MAX); + + if (!buf) + errexit(); cleartimeout(); printprompt(prompt); if (prefill) { DPRINTF_S(prefill); - len = pos = mbstowcs(buf, prefill, NAME_MAX); + len = pos = mbstowcs(buf, prefill, CMD_LEN_MAX); } else len = (size_t)-1; @@ -1821,7 +1824,7 @@ static char *xreadline(char *prefill, char *prompt) if (*ch < ASCII_MAX && keyname(*ch)[0] == '^') continue; - if (pos < NAME_MAX - 1) { + if (pos < CMD_LEN_MAX - 1) { memmove(buf + pos + 1, buf + pos, (len - pos) << 2); buf[pos] = *ch; ++len, ++pos; @@ -1869,8 +1872,9 @@ END: clearprompt(); buf[len] = '\0'; - wcstombs(g_buf + ((NAME_MAX + 1) << 2), buf, NAME_MAX); - return g_buf + ((NAME_MAX + 1) << 2); + wcstombs(g_buf, buf, ++len); + free(buf); + return g_buf; } #ifndef NORL