Source-Changes-HG archive

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

[src/trunk]: src terminfo: v3 records should create v3 aliases



details:   https://anonhg.NetBSD.org/src/rev/f21c85be9f66
branches:  trunk
changeset: 970616:f21c85be9f66
user:      roy <roy%NetBSD.org@localhost>
date:      Mon Mar 30 00:09:06 2020 +0000

description:
terminfo: v3 records should create v3 aliases

diffstat:

 lib/libterminfo/compile.c |  28 ++++++++++++++++-
 usr.bin/tic/tic.c         |  71 ++++++++++++++++++++++++++++------------------
 2 files changed, 68 insertions(+), 31 deletions(-)

diffs (179 lines):

diff -r c724f97a400b -r f21c85be9f66 lib/libterminfo/compile.c
--- a/lib/libterminfo/compile.c Mon Mar 30 00:01:57 2020 +0000
+++ b/lib/libterminfo/compile.c Mon Mar 30 00:09:06 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: compile.c,v 1.22 2020/03/29 21:46:22 roy Exp $ */
+/* $NetBSD: compile.c,v 1.23 2020/03/30 00:09:06 roy Exp $ */
 
 /*
  * Copyright (c) 2009, 2010, 2011, 2020 The NetBSD Foundation, Inc.
@@ -32,7 +32,7 @@
 #endif
 
 #include <sys/cdefs.h>
-__RCSID("$NetBSD: compile.c,v 1.22 2020/03/29 21:46:22 roy Exp $");
+__RCSID("$NetBSD: compile.c,v 1.23 2020/03/30 00:09:06 roy Exp $");
 
 #if !HAVE_NBTOOL_CONFIG_H || HAVE_SYS_ENDIAN_H
 #include <sys/endian.h>
@@ -67,7 +67,7 @@
 int
 _ti_promote(TIC *tic)
 {
-       char *obuf, type, flag;
+       char *obuf, type, flag, *buf, *delim, *name, *nbuf;
        const char *cap, *code, *str;
        size_t n, entries, strl;
        uint16_t ind;
@@ -84,6 +84,28 @@
        }
        free(obuf);
 
+       n = 0;
+       obuf = buf = tic->alias;
+       tic->alias = NULL;
+       while (buf != NULL) {
+               delim = strchr(buf, '|');
+               if (delim != NULL)
+                       *delim++ = '\0';
+               name = _ti_getname(tic->rtype, buf);
+               strl = strlen(name) + 1;
+               nbuf = realloc(tic->alias, n + strl);
+               if (nbuf == NULL) {
+                       free(name);
+                       return -1;
+               }
+               tic->alias = nbuf;
+               memcpy(tic->alias + n, name, strl);
+               n += strl;
+               free(name);
+               buf = delim;
+       }
+       free(obuf);
+
        obuf = tic->nums.buf;
        cap = obuf;
        entries = tic->nums.entries;
diff -r c724f97a400b -r f21c85be9f66 usr.bin/tic/tic.c
--- a/usr.bin/tic/tic.c Mon Mar 30 00:01:57 2020 +0000
+++ b/usr.bin/tic/tic.c Mon Mar 30 00:09:06 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: tic.c,v 1.39 2020/03/29 21:54:03 roy Exp $ */
+/* $NetBSD: tic.c,v 1.40 2020/03/30 00:09:06 roy Exp $ */
 
 /*
  * Copyright (c) 2009, 2010, 2020 The NetBSD Foundation, Inc.
@@ -32,7 +32,7 @@
 #endif
 
 #include <sys/cdefs.h>
-__RCSID("$NetBSD: tic.c,v 1.39 2020/03/29 21:54:03 roy Exp $");
+__RCSID("$NetBSD: tic.c,v 1.40 2020/03/30 00:09:06 roy Exp $");
 
 #include <sys/types.h>
 #include <sys/queue.h>
@@ -179,10 +179,37 @@
        return term;
 }
 
+static void
+alias_terms(TERM *term)
+{
+       char *p, *e, *alias;
+
+       /* Create aliased terms */
+       if (term->tic->alias == NULL)
+               return;
+
+       alias = p = estrdup(term->tic->alias);
+       while (p != NULL && *p != '\0') {
+               e = strchr(p, '|');
+               if (e != NULL)
+                       *e++ = '\0';
+               /* No need to lengthcheck the alias because the main
+                * terminfo description already stores all the aliases
+                * in the same length field as the alias. */
+               if (find_term(p) != NULL) {
+                       dowarn("%s: has alias for already assigned"
+                           " term %s", term->tic->name, p);
+               } else {
+                       store_term(p, term);
+               }
+               p = e;
+       }
+       free(alias);
+}
+
 static int
 process_entry(TBUF *buf, int flags)
 {
-       char *p, *e, *alias;
        TERM *term;
        TIC *tic;
        TBUF sbuf = *buf;
@@ -208,27 +235,7 @@
        }
        term = store_term(tic->name, NULL);
        term->tic = tic;
-
-       /* Create aliased terms */
-       if (tic->alias != NULL) {
-               alias = p = estrdup(tic->alias);
-               while (p != NULL && *p != '\0') {
-                       e = strchr(p, '|');
-                       if (e != NULL)
-                               *e++ = '\0';
-                       /* No need to lengthcheck the alias because the main
-                        * terminfo description already stores all the aliases
-                        * in the same length field as the alias. */
-                       if (find_term(p) != NULL) {
-                               dowarn("%s: has alias for already assigned"
-                                   " term %s", tic->name, p);
-                       } else {
-                               store_term(p, term);
-                       }
-                       p = e;
-               }
-               free(alias);
-       }
+       alias_terms(term);
 
        if (tic->rtype == TERMINFO_RTYPE)
                return process_entry(&sbuf, flags | TIC_COMPAT_V1);
@@ -356,6 +363,11 @@
        tic->name = _ti_getname(TERMINFO_RTYPE, rtic->name);
        if (tic->name == NULL)
                goto err;
+       if (rtic->alias != NULL) {
+               tic->alias = strdup(rtic->alias);
+               if (tic->alias == NULL)
+                       goto err;
+       }
        if (rtic->desc != NULL) {
                tic->desc = strdup(rtic->desc);
                if (tic->desc == NULL)
@@ -375,10 +387,12 @@
                goto err;
 
        term = store_term(tic->name, NULL);
-       if (term != NULL) {
-               term->tic = tic;
-               return 0;
-       }
+       if (term == NULL)
+               goto err;
+
+       term->tic = tic;
+       alias_terms(term);
+       return 0;
 
 err:
        free(tic->flags.buf);
@@ -386,6 +400,7 @@
        free(tic->strs.buf);
        free(tic->extras.buf);
        free(tic->desc);
+       free(tic->alias);
        free(tic->name);
        free(tic);
        return -1;



Home | Main Index | Thread Index | Old Index