SMOLNET PORTAL home about changes
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
Original URLgopher://bitreich.org/0/scm/stagit-gopher/commit/05a08e8a...
Content-Typetext/plain; charset=utf-8