ifix truncation and padding for lines containing multiwidth glyphs - stagit-gopher - A git gopher frontend. (mirror) Err bitreich.org 70 hgit clone git://bitreich.org/stagit-gopher/ git://enlrupgkhuxnvlhsf6lc3fziv5h2hhfrinws65d7roiv6bfj7d652fid.onion/stagit-gopher/ URL:git://bitreich.org/stagit-gopher/ git://enlrupgkhuxnvlhsf6lc3fziv5h2hhfrinws65d7roiv6bfj7d652fid.onion/stagit-gopher/ bitreich.org 70 1Log /scm/stagit-gopher/log.gph bitreich.org 70 1Files /scm/stagit-gopher/files.gph bitreich.org 70 1Refs /scm/stagit-gopher/refs.gph bitreich.org 70 1Tags /scm/stagit-gopher/tag bitreich.org 70 1README /scm/stagit-gopher/file/README.gph bitreich.org 70 1LICENSE /scm/stagit-gopher/file/LICENSE.gph bitreich.org 70 i--- Err bitreich.org 70 1commit e32410fe7894b741e141248a5e256f1e93e59fab /scm/stagit-gopher/commit/e32410fe7894b741e141248a5e256f1e93e59fab.gph bitreich.org 70 1parent c1b5e802f0d0c349faf8d4e6b6988dcfdc574488 /scm/stagit-gopher/commit/c1b5e802f0d0c349faf8d4e6b6988dcfdc574488.gph bitreich.org 70 hAuthor: Hiltjo Posthuma URL:mailto:hiltjo@codemadness.org bitreich.org 70 iDate: Sun, 1 Apr 2018 15:09:43 +0200 Err bitreich.org 70 i Err bitreich.org 70 ifix truncation and padding for lines containing multiwidth glyphs Err bitreich.org 70 i Err bitreich.org 70 iDiffstat: Err bitreich.org 70 i M stagit-gopher.c | 22 +++++++++++++--------- Err bitreich.org 70 i Err bitreich.org 70 i1 file changed, 13 insertions(+), 9 deletions(-) Err bitreich.org 70 i--- Err bitreich.org 70 1diff --git a/stagit-gopher.c b/stagit-gopher.c /scm/stagit-gopher/file/stagit-gopher.c.gph bitreich.org 70 i@@ -76,29 +76,33 @@ static const char *cachefile; Err bitreich.org 70 i int Err bitreich.org 70 i utf8pad(char *buf, size_t bufsiz, const char *s, size_t len, int pad) Err bitreich.org 70 i { Err bitreich.org 70 i- wchar_t w; Err bitreich.org 70 i+ wchar_t wc; Err bitreich.org 70 i size_t col = 0, i, slen, siz = 0; Err bitreich.org 70 i- int rl, wc; Err bitreich.org 70 i+ int rl, w; Err bitreich.org 70 i Err bitreich.org 70 i if (!len) Err bitreich.org 70 i return -1; Err bitreich.org 70 i Err bitreich.org 70 i slen = strlen(s); Err bitreich.org 70 i- for (i = 0; i < slen && col < len + 1; i += rl) { Err bitreich.org 70 i- if ((rl = mbtowc(&w, &s[i], slen - i < 4 ? slen - i : 4)) <= 0) Err bitreich.org 70 i+ for (i = 0; i < slen; i += rl) { Err bitreich.org 70 i+ if ((rl = mbtowc(&wc, &s[i], slen - i < 4 ? slen - i : 4)) <= 0) Err bitreich.org 70 i break; Err bitreich.org 70 i- if ((wc = wcwidth(w)) == -1) Err bitreich.org 70 i- wc = 1; Err bitreich.org 70 i- col += wc; Err bitreich.org 70 i- if (col >= len && s[i + rl]) { Err bitreich.org 70 i+ if ((w = wcwidth(wc)) == -1) Err bitreich.org 70 i+ continue; Err bitreich.org 70 i+ if (col + w > len || (col + w == len && s[i + rl])) { Err bitreich.org 70 i if (siz + 4 >= bufsiz) Err bitreich.org 70 i return -1; Err bitreich.org 70 i- memcpy(&buf[siz], "\xe2\x80\xa6", 4); Err bitreich.org 70 i+ memcpy(&buf[siz], "\xe2\x80\xa6", 3); Err bitreich.org 70 i+ siz += 3; Err bitreich.org 70 i+ if (col + w == len && w > 1) Err bitreich.org 70 i+ buf[siz++] = pad; Err bitreich.org 70 i+ buf[siz] = '\0'; Err bitreich.org 70 i return 0; Err bitreich.org 70 i } Err bitreich.org 70 i if (siz + rl + 1 >= bufsiz) Err bitreich.org 70 i return -1; Err bitreich.org 70 i memcpy(&buf[siz], &s[i], rl); Err bitreich.org 70 i+ col += w; Err bitreich.org 70 i siz += rl; Err bitreich.org 70 i buf[siz] = '\0'; Err bitreich.org 70 i } Err bitreich.org 70 .