iutf8pad: fix byte-seek issue with negative width codepoints in the range >= 127 - 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 05a08e8ab50a8da5b2896c3f5887801d059f48dd /scm/stagit-gopher/commit/05a08e8ab50a8da5b2896c3f5887801d059f48dd.gph bitreich.org 70
1parent a9c90b585f158f98dd0997d1509e83f85dd87498 /scm/stagit-gopher/commit/a9c90b585f158f98dd0997d1509e83f85dd87498.gph bitreich.org 70
hAuthor: Hiltjo Posthuma <hiltjo@codemadness.org> URL:mailto:hiltjo@codemadness.org bitreich.org 70
iDate: Sat, 9 Jan 2021 16:19:18 +0100 Err bitreich.org 70
i Err bitreich.org 70
iutf8pad: fix byte-seek issue with negative width codepoints in the range >= 127 Err bitreich.org 70
i Err bitreich.org 70
iFor example: "\xef\xbf\xb7" (codepoint 0xfff7), returns wcwidth(wc) == -1. Err bitreich.org 70
iThe next byte was incorrected seeked, but the codepoint itself was valid Err bitreich.org 70
i(mbtowc). Err bitreich.org 70
i Err bitreich.org 70
iDiffstat: Err bitreich.org 70
i M stagit-gopher-index.c | 7 +++---- Err bitreich.org 70
i M stagit-gopher.c | 7 +++---- Err bitreich.org 70
i Err bitreich.org 70
i2 files changed, 6 insertions(+), 8 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@@ -38,19 +38,18 @@ utf8pad(char *buf, size_t bufsiz, const char *s, size_t len, int pad) Err bitreich.org 70
i Err bitreich.org 70
i slen = strlen(s); Err bitreich.org 70
i for (i = 0; i < slen; i += inc) { Err bitreich.org 70
i- inc = 1; Err bitreich.org 70
i+ inc = 1; /* next byte */ Err bitreich.org 70
i if ((unsigned char)s[i] < 32) Err bitreich.org 70
i continue; Err bitreich.org 70
i Err bitreich.org 70
i rl = mbtowc(&wc, &s[i], slen - i < 4 ? slen - i : 4); Err bitreich.org 70
i+ inc = rl; Err bitreich.org 70
i if (rl < 0) { Err bitreich.org 70
i mbtowc(NULL, NULL, 0); /* reset state */ Err bitreich.org 70
i- inc = 1; /* next byte */ Err bitreich.org 70
i+ inc = 1; /* invalid, seek next byte */ Err bitreich.org 70
i w = 1; /* replacement char is one width */ Err bitreich.org 70
i } else if ((w = wcwidth(wc)) == -1) { Err bitreich.org 70
i continue; Err bitreich.org 70
i- } else { Err bitreich.org 70
i- inc = rl; Err bitreich.org 70
i } Err bitreich.org 70
i Err bitreich.org 70
i if (col + w > len || (col + w == len && s[i + inc])) { 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@@ -100,19 +100,18 @@ utf8pad(char *buf, size_t bufsiz, const char *s, size_t len, int pad) Err bitreich.org 70
i Err bitreich.org 70
i slen = strlen(s); Err bitreich.org 70
i for (i = 0; i < slen; i += inc) { Err bitreich.org 70
i- inc = 1; Err bitreich.org 70
i+ inc = 1; /* next byte */ Err bitreich.org 70
i if ((unsigned char)s[i] < 32) Err bitreich.org 70
i continue; Err bitreich.org 70
i Err bitreich.org 70
i rl = mbtowc(&wc, &s[i], slen - i < 4 ? slen - i : 4); Err bitreich.org 70
i+ inc = rl; Err bitreich.org 70
i if (rl < 0) { Err bitreich.org 70
i mbtowc(NULL, NULL, 0); /* reset state */ Err bitreich.org 70
i- inc = 1; /* next byte */ Err bitreich.org 70
i+ inc = 1; /* invalid, seek next byte */ Err bitreich.org 70
i w = 1; /* replacement char is one width */ Err bitreich.org 70
i } else if ((w = wcwidth(wc)) == -1) { Err bitreich.org 70
i continue; Err bitreich.org 70
i- } else { Err bitreich.org 70
i- inc = rl; Err bitreich.org 70
i } Err bitreich.org 70
i Err bitreich.org 70
i if (col + w > len || (col + w == len && s[i + inc])) { Err bitreich.org 70
.
Response:
text/plain