Source-Changes-HG archive

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

[src/trunk]: src/lib/libcurses Ignore terminfo padding specifications when ch...



details:   https://anonhg.NetBSD.org/src/rev/b025f17a869a
branches:  trunk
changeset: 994219:b025f17a869a
user:      uwe <uwe%NetBSD.org@localhost>
date:      Fri Oct 26 22:22:24 2018 +0000

description:
Ignore terminfo padding specifications when checking whether
exit_attribute_mode contains exit_alt_charset_mode.

Fixes PR lib/53653.

diffstat:

 lib/libcurses/setterm.c |  60 ++++++++++++++++++++++++++++++++++++++++--------
 1 files changed, 49 insertions(+), 11 deletions(-)

diffs (92 lines):

diff -r e624b097b58f -r b025f17a869a lib/libcurses/setterm.c
--- a/lib/libcurses/setterm.c   Fri Oct 26 22:10:15 2018 +0000
+++ b/lib/libcurses/setterm.c   Fri Oct 26 22:22:24 2018 +0000
@@ -1,4 +1,4 @@
-/*     $NetBSD: setterm.c,v 1.67 2018/10/02 17:35:44 roy Exp $ */
+/*     $NetBSD: setterm.c,v 1.68 2018/10/26 22:22:24 uwe Exp $ */
 
 /*
  * Copyright (c) 1981, 1993, 1994
@@ -34,7 +34,7 @@
 #if 0
 static char sccsid[] = "@(#)setterm.c  8.8 (Berkeley) 10/25/94";
 #else
-__RCSID("$NetBSD: setterm.c,v 1.67 2018/10/02 17:35:44 roy Exp $");
+__RCSID("$NetBSD: setterm.c,v 1.68 2018/10/26 22:22:24 uwe Exp $");
 #endif
 #endif /* not lint */
 
@@ -339,6 +339,35 @@
 }
 
 /*
+ * capdup_nodelay --
+ * A helper for does_ctrl_o below that creates a copy of the given
+ * capability with delay specifications dropped.
+ */
+static char *
+capdup_nodelay(const char *src)
+{
+       char *clean, *dst;
+
+       dst = clean = malloc(strlen(src) + 1);
+       if (__predict_false(clean == NULL))
+               return NULL;
+
+       while (*src != '\0') {
+               if (src[0] == '$' && src[1] == '<') {
+                       const char *end = strchr(src + 2, '>');
+                       if (__predict_true(end != NULL)) {
+                               src = end + 1;
+                               continue;
+                       }
+               }
+               *dst++ = *src++;
+       }
+
+       *dst = '\0';
+       return clean;
+}
+
+/*
  * does_ctrl_o --
  * A hack for vt100/xterm-like terminals where the "me" capability also
  * unsets acs.
@@ -346,19 +375,28 @@
 static int
 does_ctrl_o(const char *exit_cap, const char *acs_cap)
 {
-       const char *eptr = exit_cap, *aptr = acs_cap;
-       int l;
+       char *eptr, *aptr;
+       int res;
 
 #ifdef DEBUG
-       __CTRACE(__CTRACE_INIT, "does_ctrl_o: Testing %s for %s\n", eptr, aptr);
+       __CTRACE(__CTRACE_INIT, "does_ctrl_o: Testing %s for %s\n", exit_cap, acs_cap);
 #endif
-       l = strlen(acs_cap);
-       while (*eptr != 0) {
-               if (!strncmp(eptr, aptr, l))
-                       return 1;
-               eptr++;
+
+       eptr = capdup_nodelay(exit_cap);
+       if (__predict_false(eptr == NULL))
+               return 0;
+
+       aptr = capdup_nodelay(acs_cap);
+       if (__predict_false(aptr == NULL)) {
+               free(eptr);
+               return 0;
        }
-       return 0;
+
+       res = strstr(eptr, aptr) != NULL;
+
+       free(eptr);
+       free(aptr);
+       return res;
 }
 
 /*



Home | Main Index | Thread Index | Old Index