iimprove printutf8pad - 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 22d8f0453a32ca7e9cc13382170fc38234597a88 /scm/stagit-gopher/commit/22d8f0453a32ca7e9cc13382170fc38234597a88.gph bitreich.org 70 1parent 33f9c2a548fa4d2b31c66530ea1d14f852573187 /scm/stagit-gopher/commit/33f9c2a548fa4d2b31c66530ea1d14f852573187.gph bitreich.org 70 hAuthor: Hiltjo Posthuma URL:mailto:hiltjo@codemadness.org bitreich.org 70 iDate: Fri, 23 Jun 2017 12:26:28 +0200 Err bitreich.org 70 i Err bitreich.org 70 iimprove printutf8pad Err bitreich.org 70 i Err bitreich.org 70 icorrect truncation and count of utf-8 runes using mbtowc Err bitreich.org 70 i Err bitreich.org 70 iDiffstat: Err bitreich.org 70 i M stagit-gopher-index.c | 34 ++++++++++++++++---------------- Err bitreich.org 70 i M stagit-gopher.c | 35 +++++++++++++++---------------- Err bitreich.org 70 i Err bitreich.org 70 i2 files changed, 34 insertions(+), 35 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@@ -25,32 +25,32 @@ static char *name = ""; Err bitreich.org 70 i #define pledge(p1,p2) 0 Err bitreich.org 70 i #endif Err bitreich.org 70 i Err bitreich.org 70 i-#define ISUTF8(c) (((c) & 0xc0) != 0x80) Err bitreich.org 70 i- Err bitreich.org 70 i /* print `len' columns of characters. If string is shorter pad the rest Err bitreich.org 70 i * with characters `pad`. */ Err bitreich.org 70 i void Err bitreich.org 70 i printutf8pad(FILE *fp, 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- size_t n = 0, i; Err bitreich.org 70 i- int r; Err bitreich.org 70 i+ size_t col = 0, i, slen; Err bitreich.org 70 i+ int rl, wc; Err bitreich.org 70 i+ Err bitreich.org 70 i+ if (!len) Err bitreich.org 70 i+ return; Err bitreich.org 70 i Err bitreich.org 70 i- for (i = 0; *s && n < len; i++, s++) { Err bitreich.org 70 i- if (ISUTF8(*s)) { Err bitreich.org 70 i- if ((r = mbtowc(&w, s, 4)) == -1) Err bitreich.org 70 i- break; Err bitreich.org 70 i- if ((r = wcwidth(w)) == -1) Err bitreich.org 70 i- r = 1; Err bitreich.org 70 i- n += (size_t)r; Err bitreich.org 70 i- if (n >= len) { Err bitreich.org 70 i- fputs("\xe2\x80\xa6", fp); Err bitreich.org 70 i- break; 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+ break; Err bitreich.org 70 i+ if ((wc = wcwidth(w)) == -1) Err bitreich.org 70 i+ wc = 1; Err bitreich.org 70 i+ col += (size_t)wc; Err bitreich.org 70 i+ if (col >= len && s[i + rl]) { Err bitreich.org 70 i+ fputs("\xe2\x80\xa6", fp); Err bitreich.org 70 i+ break; Err bitreich.org 70 i } Err bitreich.org 70 i- putc(*s, fp); Err bitreich.org 70 i+ fwrite(&s[i], 1, rl, fp); Err bitreich.org 70 i } Err bitreich.org 70 i- for (; n < len; n++) Err bitreich.org 70 i+ for (; col < len; col++) Err bitreich.org 70 i putc(pad, fp); Err bitreich.org 70 i } 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@@ -68,33 +68,32 @@ static const char *cachefile; Err bitreich.org 70 i #define pledge(p1,p2) 0 Err bitreich.org 70 i #endif Err bitreich.org 70 i Err bitreich.org 70 i-#define ISUTF8(c) (((c) & 0xc0) != 0x80) Err bitreich.org 70 i- Err bitreich.org 70 i /* print `len' columns of characters. If string is shorter pad the rest Err bitreich.org 70 i * with characters `pad`. */ Err bitreich.org 70 i void Err bitreich.org 70 i printutf8pad(FILE *fp, 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- size_t n = 0, i; Err bitreich.org 70 i- int r; Err bitreich.org 70 i+ size_t col = 0, i, slen; Err bitreich.org 70 i+ int rl, wc; Err bitreich.org 70 i Err bitreich.org 70 i- for (i = 0; *s && n < len; i++, s++) { Err bitreich.org 70 i- if (ISUTF8(*s)) { Err bitreich.org 70 i- if (mbtowc(&w, s, 4) == -1) Err bitreich.org 70 i- break; Err bitreich.org 70 i- if ((r = wcwidth(w)) == -1) Err bitreich.org 70 i- r = 1; Err bitreich.org 70 i- n += (size_t)r; Err bitreich.org 70 i- if (n >= len) { Err bitreich.org 70 i- fputs("\xe2\x80\xa6", fp); Err bitreich.org 70 i- break; Err bitreich.org 70 i- } Err bitreich.org 70 i+ if (!len) Err bitreich.org 70 i+ return; 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+ break; Err bitreich.org 70 i+ if ((wc = wcwidth(w)) == -1) Err bitreich.org 70 i+ wc = 1; Err bitreich.org 70 i+ col += (size_t)wc; Err bitreich.org 70 i+ if (col >= len && s[i + rl]) { Err bitreich.org 70 i+ fputs("\xe2\x80\xa6", fp); Err bitreich.org 70 i+ break; Err bitreich.org 70 i } Err bitreich.org 70 i- putc(*s, fp); Err bitreich.org 70 i+ fwrite(&s[i], 1, rl, fp); Err bitreich.org 70 i } Err bitreich.org 70 i- Err bitreich.org 70 i- for (; n < len; n++) Err bitreich.org 70 i+ for (; col < len; col++) Err bitreich.org 70 i putc(pad, fp); Err bitreich.org 70 i } Err bitreich.org 70 i Err bitreich.org 70 .