Source-Changes-HG archive

[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]

[src/trunk]: src/lib/libc/gen Grr need to deal with isgraph(3). Is there a be...



details:   https://anonhg.NetBSD.org/src/rev/179f045265d4
branches:  trunk
changeset: 338421:179f045265d4
user:      christos <christos%NetBSD.org@localhost>
date:      Sat May 23 14:01:07 2015 +0000

description:
Grr need to deal with isgraph(3). Is there a better way?

diffstat:

 lib/libc/gen/vis.c |  27 +++++++++++++++++++++++----
 1 files changed, 23 insertions(+), 4 deletions(-)

diffs (62 lines):

diff -r cab6de9ee37c -r 179f045265d4 lib/libc/gen/vis.c
--- a/lib/libc/gen/vis.c        Sat May 23 13:44:40 2015 +0000
+++ b/lib/libc/gen/vis.c        Sat May 23 14:01:07 2015 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: vis.c,v 1.67 2015/05/23 11:47:56 christos Exp $        */
+/*     $NetBSD: vis.c,v 1.68 2015/05/23 14:01:07 christos Exp $        */
 
 /*-
  * Copyright (c) 1989, 1993
@@ -57,7 +57,7 @@
 
 #include <sys/cdefs.h>
 #if defined(LIBC_SCCS) && !defined(lint)
-__RCSID("$NetBSD: vis.c,v 1.67 2015/05/23 11:47:56 christos Exp $");
+__RCSID("$NetBSD: vis.c,v 1.68 2015/05/23 14:01:07 christos Exp $");
 #endif /* LIBC_SCCS and not lint */
 #ifdef __FBSDID
 __FBSDID("$FreeBSD$");
@@ -97,6 +97,25 @@
 
 #undef BELL
 #define BELL L'\a'
+ 
+#if defined(__NetBSD__) && defined(_CTYPE_G)
+#define iscgraph(c)      ((int)((_C_ctype_tab_ + 1)[(c)] & _CTYPE_G)) 
+#else
+static int
+iscgraph(int c) {
+       int rv;
+       char *ol;
+
+       ol = setlocale(LC_CTYPE, "C");
+       rv = isgraph(c);
+       if (ol)
+               setlocale(LC_CTYPE, ol);
+       return rv;
+}
+#endif
+
+#define ISGRAPH(flags, c) \
+    (((flags) & VIS_NOLOCALE) ? iscgraph(c) : iswgraph(c))
 
 #define iswoctal(c)    (((u_char)(c)) >= L'0' && ((u_char)(c)) <= L'7')
 #define iswwhite(c)    (c == L' ' || c == L'\t' || c == L'\n')
@@ -232,7 +251,7 @@
                case L'$': /* vis(1) -l */
                        break;
                default:
-                       if (iswgraph(c) && !iswoctal(c)) {
+                       if (ISGRAPH(flags, c) && !iswoctal(c)) {
                                *dst++ = L'\\';
                                *dst++ = c;
                                return dst;
@@ -284,7 +303,7 @@
        uint64_t bmsk, wmsk;
 
        iswextra = wcschr(extra, c) != NULL;
-       if (!iswextra && (iswgraph(c) || iswwhite(c) ||
+       if (!iswextra && (ISGRAPH(flags, c) || iswwhite(c) ||
            ((flags & VIS_SAFE) && iswsafe(c)))) {
                *dst++ = c;
                return dst;



Home | Main Index | Thread Index | Old Index