istagit-gopher-index: sync utf8pad from stagit-gopher.c - 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 8091f757ce641307bcdc69c9e5348ef54ab82e5c /scm/stagit-gopher/commit/8091f757ce641307bcdc69c9e5348ef54ab82e5c.gph bitreich.org 70 1parent 70e0e50a6c4d83f7b809be4338bcf2868c13b49b /scm/stagit-gopher/commit/70e0e50a6c4d83f7b809be4338bcf2868c13b49b.gph bitreich.org 70 hAuthor: Hiltjo Posthuma URL:mailto:hiltjo@codemadness.org bitreich.org 70 iDate: Fri, 8 Jan 2021 14:30:44 +0100 Err bitreich.org 70 i Err bitreich.org 70 istagit-gopher-index: sync utf8pad from stagit-gopher.c Err bitreich.org 70 i Err bitreich.org 70 iSyncs a fix from commit e32410fe: Err bitreich.org 70 i"fix 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-index.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-index.c b/stagit-gopher-index.c /scm/stagit-gopher/file/stagit-gopher-index.c.gph bitreich.org 70 i@@ -22,29 +22,33 @@ static char *name = ""; 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 .