Source-Changes-HG archive
[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index][Old Index]
[src/trunk]: src/lib/libterminfo Fix some off by one issues with arraycount ....
details:   https://anonhg.NetBSD.org/src/rev/b7d4871f360d
branches:  trunk
changeset: 820590:b7d4871f360d
user:      roy <roy%NetBSD.org@localhost>
date:      Wed Jan 11 20:53:52 2017 +0000
description:
Fix some off by one issues with arraycount ..thanks coypu.
diffstat:
 lib/libterminfo/genhash   |   6 +++---
 lib/libterminfo/termcap.c |  16 ++++++++--------
 2 files changed, 11 insertions(+), 11 deletions(-)
diffs (100 lines):
diff -r 4a339624c325 -r b7d4871f360d lib/libterminfo/genhash
--- a/lib/libterminfo/genhash   Wed Jan 11 20:43:03 2017 +0000
+++ b/lib/libterminfo/genhash   Wed Jan 11 20:53:52 2017 +0000
@@ -1,5 +1,5 @@
 #!/bin/sh
-# $NetBSD: genhash,v 1.8 2011/11/02 12:09:25 roy Exp $
+# $NetBSD: genhash,v 1.9 2017/01/11 20:53:52 roy Exp $
 
 # Copyright (c) 2009, 2011 The NetBSD Foundation, Inc.
 #
@@ -65,7 +65,7 @@
 _ti_${name}id(ssize_t idx)
 {
 
-       if ((size_t)idx > __arraycount(_ti_${name}ids))
+       if ((size_t)idx >= __arraycount(_ti_${name}ids))
                return NULL;
        return _ti_${name}ids[idx];
 }
@@ -76,7 +76,7 @@
        uint32_t idx;
 
        idx = _ti_${name}hash((const unsigned char *)key, strlen(key));
-       if (idx > __arraycount(_ti_${name}ids) ||
+       if (idx >= __arraycount(_ti_${name}ids) ||
            strcmp(key, _ti_${name}ids[idx]) != 0)
                return -1;
        return idx;
diff -r 4a339624c325 -r b7d4871f360d lib/libterminfo/termcap.c
--- a/lib/libterminfo/termcap.c Wed Jan 11 20:43:03 2017 +0000
+++ b/lib/libterminfo/termcap.c Wed Jan 11 20:53:52 2017 +0000
@@ -1,4 +1,4 @@
-/* $NetBSD: termcap.c,v 1.19 2016/04/01 19:59:08 christos Exp $ */
+/* $NetBSD: termcap.c,v 1.20 2017/01/11 20:53:52 roy Exp $ */
 
 /*
  * Copyright (c) 2009 The NetBSD Foundation, Inc.
@@ -28,7 +28,7 @@
  */
 
 #include <sys/cdefs.h>
-__RCSID("$NetBSD: termcap.c,v 1.19 2016/04/01 19:59:08 christos Exp $");
+__RCSID("$NetBSD: termcap.c,v 1.20 2017/01/11 20:53:52 roy Exp $");
 
 #include <assert.h>
 #include <ctype.h>
@@ -88,7 +88,7 @@
                return 0;
 
        ind = _t_flaghash((const unsigned char *)id, strlen(id));
-       if (ind <= __arraycount(_ti_cap_flagids)) {
+       if (ind < __arraycount(_ti_cap_flagids)) {
                if (strcmp(id, _ti_cap_flagids[ind].id) == 0)
                        return cur_term->flags[_ti_cap_flagids[ind].ti];
        }
@@ -113,7 +113,7 @@
                return -1;
 
        ind = _t_numhash((const unsigned char *)id, strlen(id));
-       if (ind <= __arraycount(_ti_cap_numids)) {
+       if (ind < __arraycount(_ti_cap_numids)) {
                te = &_ti_cap_numids[ind];
                if (strcmp(id, te->id) == 0) {
                        if (!VALID_NUMERIC(cur_term->nums[te->ti]))
@@ -146,7 +146,7 @@
 
        str = NULL;
        ind = _t_strhash((const unsigned char *)id, strlen(id));
-       if (ind <= __arraycount(_ti_cap_strids)) {
+       if (ind < __arraycount(_ti_cap_strids)) {
                if (strcmp(id, _ti_cap_strids[ind].id) == 0) {
                        str = cur_term->strs[_ti_cap_strids[ind].ti];
                        if (str == NULL)
@@ -188,7 +188,7 @@
        uint32_t idx;
 
        idx = _t_flaghash((const unsigned char *)key, strlen(key));
-       if (idx <= __arraycount(_ti_cap_flagids) &&
+       if (idx < __arraycount(_ti_cap_flagids) &&
            strcmp(key, _ti_cap_flagids[idx].id) == 0)
                return _ti_flagid(_ti_cap_flagids[idx].ti);
        return key;
@@ -200,7 +200,7 @@
        uint32_t idx;
 
        idx = _t_numhash((const unsigned char *)key, strlen(key));
-       if (idx <= __arraycount(_ti_cap_numids) && 
+       if (idx < __arraycount(_ti_cap_numids) && 
            strcmp(key, _ti_cap_numids[idx].id) == 0)
                return _ti_numid(_ti_cap_numids[idx].ti);
        return key;
@@ -212,7 +212,7 @@
        uint32_t idx;
 
        idx = _t_strhash((const unsigned char *)key, strlen(key));
-       if (idx <= __arraycount(_ti_cap_strids) &&
+       if (idx < __arraycount(_ti_cap_strids) &&
            strcmp(key, _ti_cap_strids[idx].id) == 0)
                return _ti_strid(_ti_cap_strids[idx].ti);
 
Home |
Main Index |
Thread Index |
Old Index