summaryrefslogtreecommitdiffstats
path: root/lib/libtermcap
diff options
context:
space:
mode:
authorache <ache@FreeBSD.org>1995-03-26 00:35:36 +0000
committerache <ache@FreeBSD.org>1995-03-26 00:35:36 +0000
commitb3e27092b54526d1808a5819ebea702f20e7bce3 (patch)
tree35e1763c2249440fdc256ce7fa7c9e95ebe9cf37 /lib/libtermcap
parent1b63b57e4bd49802bffca218ad1fc3d7d168224c (diff)
downloadFreeBSD-src-b3e27092b54526d1808a5819ebea702f20e7bce3.zip
FreeBSD-src-b3e27092b54526d1808a5819ebea702f20e7bce3.tar.gz
Compact entry returned to user:
1) Eliminate spaces and double ':'. 2) Remove duplicated capabilities from tc= expansion. It is needed to not overflow historycal 1024 limit. Add range check and return -1 if entry is too big instead of corrupting user memory.
Diffstat (limited to 'lib/libtermcap')
-rw-r--r--lib/libtermcap/termcap.c52
1 files changed, 49 insertions, 3 deletions
diff --git a/lib/libtermcap/termcap.c b/lib/libtermcap/termcap.c
index 51f0288..3b9e15e 100644
--- a/lib/libtermcap/termcap.c
+++ b/lib/libtermcap/termcap.c
@@ -37,6 +37,7 @@ static char sccsid[] = "@(#)termcap.c 8.1 (Berkeley) 6/4/93";
#define PBUFSIZ 512 /* max length of filename path */
#define PVECSIZ 32 /* max number of names in path */
+#define TBUFSIZ 1024 /* max length of tgetent buffer */
#include <stdio.h>
#include <ctype.h>
@@ -131,9 +132,54 @@ tgetent(bp, name)
i = cgetent(&dummy, pathvec, name);
- if (i == 0)
- strcpy(bp, dummy);
-
+ if (i == 0) {
+ char *pd, *ps, *tok, *s, *tcs;
+ size_t len;
+
+ pd = bp;
+ ps = dummy;
+ if ((tok = strchr(ps, ':')) == NULL) {
+ len = strlen(ps);
+ if (len >= TBUFSIZ)
+ i = -1;
+ else
+ strcpy(pd, ps);
+ goto done;
+ }
+ len = tok - ps + 1;
+ if (pd + len + 1 - bp >= TBUFSIZ) {
+ i = -1;
+ goto done;
+ }
+ memcpy(pd, ps, len);
+ ps += len;
+ pd += len;
+ *pd = '\0';
+ tcs = pd - 1;
+ for (;;) {
+ while ((tok = strsep(&ps, ":")) != NULL &&
+ (*tok == '\0' || !isgraph(*tok)))
+ ;
+ if (tok == NULL)
+ break;
+ for (s = tcs; s != NULL && s[1] != '\0'; s = strchr(s, ':')) {
+ s++;
+ if (s[0] == tok[0] && s[1] == tok[1])
+ goto skip_it;
+ }
+ len = strlen(tok);
+ if (pd + len + 1 - bp >= TBUFSIZ) {
+ i = -1;
+ break;
+ }
+ memcpy(pd, tok, len);
+ pd += len;
+ *pd++ = ':';
+ *pd = '\0';
+ skip_it: ;
+ }
+ }
+done:
if (dummy)
free(dummy);
/* no tc reference loop return code in libterm XXX */
OpenPOWER on IntegriCloud