Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/lib/libcurses Make sure we don't use wide char routines when...
details: https://anonhg.NetBSD.org/src/rev/a2ea300ad1b5
branches: trunk
changeset: 1021902:a2ea300ad1b5
user: blymn <blymn%NetBSD.org@localhost>
date: Thu Jun 24 05:53:05 2021 +0000
description:
Make sure we don't use wide char routines when DISABLE_WCHAR is in
effect.
diffstat:
lib/libcurses/slk.c | 20 +++++++++++++++++---
1 files changed, 17 insertions(+), 3 deletions(-)
diffs (67 lines):
diff -r 6d36830a3730 -r a2ea300ad1b5 lib/libcurses/slk.c
--- a/lib/libcurses/slk.c Thu Jun 24 01:23:16 2021 +0000
+++ b/lib/libcurses/slk.c Thu Jun 24 05:53:05 2021 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: slk.c,v 1.9 2021/06/22 07:26:45 blymn Exp $ */
+/* $NetBSD: slk.c,v 1.10 2021/06/24 05:53:05 blymn Exp $ */
/*-
* Copyright (c) 2017 The NetBSD Foundation, Inc.
@@ -31,7 +31,7 @@
#include <sys/cdefs.h>
#ifndef lint
-__RCSID("$NetBSD: slk.c,v 1.9 2021/06/22 07:26:45 blymn Exp $");
+__RCSID("$NetBSD: slk.c,v 1.10 2021/06/24 05:53:05 blymn Exp $");
#endif /* not lint */
#include <ctype.h>
@@ -818,9 +818,11 @@
{
const struct __slk_label *l;
int retval, inc, lcnt, tx;
+ char ts[MB_CUR_MAX];
+#ifdef HAVE_WCHAR
cchar_t cc;
wchar_t wc[2];
- char ts[MB_CUR_MAX];
+#endif
if (screen->slk_hidden)
return OK;
@@ -855,23 +857,35 @@
__CTRACE(__CTRACE_INPUT, "__slk_draw: label len %d, wcwidth %d\n",
screen->slk_label_len, wcwidth(l->label[lcnt]));
#endif
+#ifdef HAVE_WCHAR
wc[0] = l->label[lcnt];
wc[1] = L'\0';
if (setcchar(&cc, wc,
screen->slk_window->wattr, 0,
NULL) == ERR)
return ERR;
+#endif
if (l->x + wcwidth(l->label[lcnt] + tx) >=
screen->slk_label_len) {
/* last character that will fit
* so insert it to avoid scroll
*/
+#ifdef HAVE_WCHAR
retval = mvwins_wch(screen->slk_window,
0, l->x + tx, &cc);
+#else
+ retval = mvwinsch(screen->slk_window,
+ 0, l->x + tx, l->label[lcnt]);
+#endif
} else {
+#ifdef HAVE_WCHAR
retval = mvwadd_wch(screen->slk_window,
0, l->x + tx, &cc);
+#else
+ retval = mvwaddch(screen->slk_window,
+ 0, l->x + tx, l->label[lcnt]);
+#endif
}
tx += wcwidth(l->label[lcnt]);
lcnt += inc;
Home |
Main Index |
Thread Index |
Old Index