Zsh Mailing List Archive
Messages sorted by:
Reverse Date,
Date,
Thread,
Author
Re: [BUG]select command display in wrong
- X-seq: zsh-workers 53294
- From: Bart Schaefer <schaefer@xxxxxxxxxxxxxxxx>
- To: safreya <safreya@xxxxxx>
- Cc: zsh-workers@xxxxxxx
- Subject: Re: [BUG]select command display in wrong
- Date: Mon, 30 Dec 2024 20:11:54 -0800
- Archived-at: <https://zsh.org/workers/53294>
- In-reply-to: <CAH+w=7ZVozoyJwRdO4Mapg4asbejXaoWaK6rQ5s+My_zBPOBYA@mail.gmail.com>
- List-id: <zsh-workers.zsh.org>
- References: <tencent_63654B61CCD0966D73F5A25824618A84D505@qq.com> <CAH+w=7ZUTNSLJ74tZv4sy7=YYisrZK7xtwgU_7kkMCFsVioiBQ@mail.gmail.com> <CAH+w=7ZVozoyJwRdO4Mapg4asbejXaoWaK6rQ5s+My_zBPOBYA@mail.gmail.com>
On Fri, Dec 27, 2024 at 2:58 PM Bart Schaefer <schaefer@xxxxxxxxxxxxxxxx> wrote:
>
> After a second look, this is somewhat better; it may still get the
> columnation wrong if the visual length is different than the string
> length.
Here's a third try, correcting for visual widths as best I think we can.
diff --git a/Src/loop.c b/Src/loop.c
index 84dc66476..979285abc 100644
--- a/Src/loop.c
+++ b/Src/loop.c
@@ -351,9 +351,16 @@ selectlist(LinkList l, size_t start)
zleentry(ZLE_CMD_TRASH);
arr = hlinklist2array(l, 0);
- for (ap = arr; *ap; ap++)
- if (strlen(*ap) > longest)
- longest = strlen(*ap);
+ for (ap = arr; *ap; ap++) {
+#ifdef MB_METASTRWIDTH
+ int aplen = MB_METASTRWIDTH(*ap);
+#else
+ int aplen = 0;
+ (void) unmetafy(*ap, &aplen);
+#endif
+ if (aplen > longest)
+ longest = aplen;
+ }
t0 = ct = ap - arr;
longest++;
while (t0)
@@ -368,7 +375,12 @@ selectlist(LinkList l, size_t start)
for (t1 = start; t1 != colsz && t1 - start < zterm_lines - 2; t1++) {
ap = arr + t1;
do {
+#ifdef MB_METASTRWIDTH
+ size_t t2 = MB_METASTRWIDTH(*ap) + 2;
+ (void) unmetafy(*ap, NULL);
+#else
size_t t2 = strlen(*ap) + 2;
+#endif
int t3;
fprintf(stderr, "%d) %s", t3 = ap - arr + 1, *ap);
Messages sorted by:
Reverse Date,
Date,
Thread,
Author