Source-Changes-HG archive

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

[src/trunk]: src/usr.bin/tic Use the new functions and add more error checking.



details:   https://anonhg.NetBSD.org/src/rev/aba29d0c5c8e
branches:  trunk
changeset: 746306:aba29d0c5c8e
user:      christos <christos%NetBSD.org@localhost>
date:      Fri Mar 27 17:42:36 2020 +0000

description:
Use the new functions and add more error checking.

diffstat:

 usr.bin/tic/tic.c |  75 ++++++++++++++++++++++---------------------------------
 1 files changed, 30 insertions(+), 45 deletions(-)

diffs (156 lines):

diff -r 4b69da536049 -r aba29d0c5c8e usr.bin/tic/tic.c
--- a/usr.bin/tic/tic.c Fri Mar 27 17:39:53 2020 +0000
+++ b/usr.bin/tic/tic.c Fri Mar 27 17:42:36 2020 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: tic.c,v 1.33 2020/03/27 15:11:57 christos Exp $ */
+/* $NetBSD: tic.c,v 1.34 2020/03/27 17:42:36 christos 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.33 2020/03/27 15:11:57 christos Exp $");
+__RCSID("$NetBSD: tic.c,v 1.34 2020/03/27 17:42:36 christos Exp $");
 
 #include <sys/types.h>
 #include <sys/queue.h>
@@ -104,12 +104,13 @@
        size_t slen = strlen(term->name) + 1;
 
        if (term->base_term != NULL) {
-               len = (ssize_t)slen + 7;
+               char *cap;
+               len = (ssize_t)(1 + sizeof(uint32_t) + sizeof(uint16_t) + slen);
                buf = emalloc(len);
-               buf[0] = TERMINFO_ALIAS;
-               le32enc(buf + 1, term->base_term->id);
-               le16enc(buf + 5, slen);
-               memcpy(buf + 7, term->name, slen);
+               cap = (char *)buf;
+               *cap++ = TERMINFO_ALIAS;
+               _ti_encode_32(&cap, term->base_term->id);
+               _ti_encode_count_str(&cap, term->name, slen);
                if (cdbw_put(db, term->name, slen, buf, len))
                        err(1, "cdbw_put");
                free(buf);
@@ -229,63 +230,47 @@
 
        cap = utic->flags.buf;
        for (n = utic->flags.entries; n > 0; n--) {
-               ind = le16dec(cap);
-               cap += sizeof(uint16_t);
+               ind = _ti_decode_16(&cap);
                flag = *cap++;
                if (VALID_BOOLEAN(flag) &&
                    _ti_find_cap(rtic, &rtic->flags, 'f', ind) == NULL)
                {
-                       _ti_grow_tbuf(&rtic->flags, sizeof(uint16_t) + 1);
-                       le16enc(rtic->flags.buf + rtic->flags.bufpos, ind);
-                       rtic->flags.bufpos += sizeof(uint16_t);
-                       rtic->flags.buf[rtic->flags.bufpos++] = flag;
-                       rtic->flags.entries++;
+                       if (!_ti_encode_buf_id_flags(&rtic->flags, ind, flag))
+                               err(1, "encode flag");
                }
        }
 
        cap = utic->nums.buf;
        for (n = utic->nums.entries; n > 0; n--) {
-               ind = le16dec(cap);
-               cap += sizeof(uint16_t);
-               num = _ti_decode_num(utic->rtype, &cap);
+               ind = _ti_decode_16(&cap);
+               num = _ti_decode_num(&cap, utic->rtype);
                if (VALID_NUMERIC(num) &&
                    _ti_find_cap(rtic, &rtic->nums, 'n', ind) == NULL)
                {
-                       grow_tbuf(&rtic->nums, sizeof(uint16_t) +
-                           _ti_numsize(rtic));
-                       le16enc(rtic->nums.buf + rtic->nums.bufpos, ind);
-                       rtic->nums.bufpos += sizeof(uint16_t);
-                       _ti_encode_num(rtic, &rtic->nums, num);
-                       rtic->nums.entries++;
+                       if (!_ti_encode_buf_id_num(&rtic->nums, ind, num,
+                           _ti_numsize(rtic)))
+                               err(1, "encode num");
                }
        }
 
        cap = utic->strs.buf;
        for (n = utic->strs.entries; n > 0; n--) {
-               ind = le16dec(cap);
-               cap += sizeof(uint16_t);
-               len = le16dec(cap);
-               cap += sizeof(uint16_t);
+               ind = _ti_decode_16(&cap);
+               len = _ti_decode_16(&cap);
                if (len > 0 &&
                    _ti_find_cap(rtic, &rtic->strs, 's', ind) == NULL)
                {
-                       grow_tbuf(&rtic->strs, (sizeof(uint16_t) * 2) + len);
-                       le16enc(rtic->strs.buf + rtic->strs.bufpos, ind);
-                       rtic->strs.bufpos += sizeof(uint16_t);
-                       le16enc(rtic->strs.buf + rtic->strs.bufpos, len);
-                       rtic->strs.bufpos += sizeof(uint16_t);
-                       memcpy(rtic->strs.buf + rtic->strs.bufpos,
-                           cap, len);
-                       rtic->strs.bufpos += len;
-                       rtic->strs.entries++;
+                       if (!_ti_encode_buf_id_count_str(&rtic->strs, ind, cap,
+                           len))
+                               err(1, "encode str");
+                               
                }
                cap += len;
        }
 
        cap = utic->extras.buf;
        for (n = utic->extras.entries; n > 0; n--) {
-               num = le16dec(cap);
-               cap += sizeof(uint16_t);
+               num = _ti_decode_16(&cap);
                code = cap;
                cap += num;
                type = *cap++;
@@ -298,13 +283,12 @@
                                continue;
                        break;
                case 'n':
-                       num = _ti_decode_num(utic->rtype, &cap);
+                       num = _ti_decode_num(&cap, utic->rtype);
                        if (!VALID_NUMERIC(num))
                                continue;
                        break;
                case 's':
-                       num = le16dec(cap);
-                       cap += sizeof(uint16_t);
+                       num = _ti_decode_16(&cap);
                        str = cap;
                        cap += num;
                        if (num == 0)
@@ -320,7 +304,7 @@
 merge_use(int flags)
 {
        size_t skipped, merged, memn;
-       char *cap, *scap;
+       const char *cap;
        uint16_t num;
        TIC *rtic, *utic;
        TERM *term, *uterm;;
@@ -368,10 +352,11 @@
                                dowarn("%s: use no longer exists - impossible",
                                        rtic->name);
                        else {
-                               scap = cap - (4 + sizeof(uint16_t));
+                               char *scap = __UNCONST(
+                                   cap - (4 + sizeof(uint16_t)));
                                cap++;
-                               num = le16dec(cap);
-                               cap += sizeof(uint16_t) + num;
+                               num = _ti_decode_16(&cap);
+                               cap += num;
                                memn = rtic->extras.bufpos -
                                    (cap - rtic->extras.buf);
                                memmove(scap, cap, memn);



Home | Main Index | Thread Index | Old Index