diff options
author | Kevin Lo <kevlo@FreeBSD.org> | 2000-10-28 16:13:06 +0000 |
---|---|---|
committer | Kevin Lo <kevlo@FreeBSD.org> | 2000-10-28 16:13:06 +0000 |
commit | fe660b35732a2be7063ead8ee6a67b2b2f14f55d (patch) | |
tree | 21ffa5a79690d43748091200a1ba2040c7b52bf3 /cad/cider | |
parent | 20eb6aadc91b62548cbaf4031b6706ac4e68438c (diff) |
- Prevent possible buffer overflow
- Use erfc(3).
PR: 22343
Submitted by: MAINTAINER
Notes
Notes:
svn path=/head/; revision=34369
Diffstat (limited to 'cad/cider')
-rw-r--r-- | cad/cider/Makefile | 1 | ||||
-rw-r--r-- | cad/cider/files/patch-ad | 27 | ||||
-rw-r--r-- | cad/cider/files/patch-bc | 27 | ||||
-rw-r--r-- | cad/cider/files/patch-bm | 16 |
4 files changed, 47 insertions, 24 deletions
diff --git a/cad/cider/Makefile b/cad/cider/Makefile index 1365de2efd51..b58de3ab955a 100644 --- a/cad/cider/Makefile +++ b/cad/cider/Makefile @@ -7,6 +7,7 @@ PORTNAME= cider PORTVERSION= 1.b1 +PORTREVISION= 1 CATEGORIES= cad MASTER_SITES= ftp://ic.eecs.berkeley.edu/pub/Cider/new/ DISTNAME= cider1b1 diff --git a/cad/cider/files/patch-ad b/cad/cider/files/patch-ad index 84164a6a64d8..e23701f545f1 100644 --- a/cad/cider/files/patch-ad +++ b/cad/cider/files/patch-ad @@ -1,5 +1,5 @@ *** spice/common/src/bin/main.c.orig Sat Mar 12 08:22:28 1994 ---- spice/common/src/bin/main.c Sun Dec 12 14:58:04 1999 +--- spice/common/src/bin/main.c Tue Oct 24 03:32:20 2000 *************** *** 25,30 **** --- 25,37 ---- @@ -46,7 +46,7 @@ #ifdef BATCH *************** *** 185,190 **** ---- 202,291 ---- +--- 202,294 ---- #endif @@ -56,6 +56,7 @@ + prompt() + { + static char pbuf[128]; ++ int n = sizeof(pbuf); + char *p = pbuf, *s; + + if (cp_interactive == false) @@ -66,16 +67,18 @@ + s = cp_promptstring; + if (cp_altprompt) + s = cp_altprompt; -+ while (*s) { ++ while (*s && (n > 1)) { ++ int w; + switch (strip(*s)) { + case '!': -+ p += sprintf(p, "%d", where_history() + 1); ++ w = snprintf(p, n, "%d", where_history() + 1); ++ w = (w >= n) ? n - 1 : w; ++ p += w; ++ n -= w; + break; -+ case '\\': -+ if (*(s + 1)) -+ p += sprintf(p, "%c", strip(*++s)); + default: + *p = strip(*s); ++p; ++ --n; + break; + } + s++; @@ -139,7 +142,7 @@ void *************** *** 216,221 **** ---- 317,326 ---- +--- 320,329 ---- #endif @@ -152,7 +155,7 @@ fprintf(cp_err, "main: Internal Error: jump to zero\n"); *************** *** 236,241 **** ---- 341,353 ---- +--- 344,356 ---- ARCHsize = 1; #endif /* PARALLEL_ARCH */ @@ -168,7 +171,7 @@ #endif *************** *** 472,478 **** ---- 584,594 ---- +--- 587,597 ---- # ifdef HAS_UNIX_SIGS /* Set up (void) signal handling */ if (!ft_batchmode) { @@ -182,7 +185,7 @@ (void) signal(SIGTSTP, sigstop); *************** *** 668,674 **** ---- 784,794 ---- +--- 787,797 ---- } else { (void) setjmp(jbuf); cp_interactive = true; @@ -196,7 +199,7 @@ # else /* if BATCH */ *************** *** 708,714 **** ---- 828,838 ---- +--- 831,841 ---- /* Nutmeg "main" */ (void) setjmp(jbuf); cp_interactive = true; diff --git a/cad/cider/files/patch-bc b/cad/cider/files/patch-bc index 8924482f58f7..1b7d06886f7c 100644 --- a/cad/cider/files/patch-bc +++ b/cad/cider/files/patch-bc @@ -1,5 +1,5 @@ *** cider/common/src/bin/main.c.orig Sat Mar 12 08:20:59 1994 ---- cider/common/src/bin/main.c Mon Dec 13 10:16:13 1999 +--- cider/common/src/bin/main.c Tue Oct 24 03:37:38 2000 *************** *** 25,30 **** --- 25,37 ---- @@ -46,7 +46,7 @@ #ifdef BATCH *************** *** 185,190 **** ---- 202,291 ---- +--- 202,294 ---- #endif @@ -56,6 +56,7 @@ + prompt() + { + static char pbuf[128]; ++ int n = sizeof(pbuf); + char *p = pbuf, *s; + + if (cp_interactive == false) @@ -66,16 +67,18 @@ + s = cp_promptstring; + if (cp_altprompt) + s = cp_altprompt; -+ while (*s) { ++ while (*s && (n > 1)) { ++ int w; + switch (strip(*s)) { + case '!': -+ p += sprintf(p, "%d", where_history() + 1); ++ w = snprintf(p, n, "%d", where_history() + 1); ++ w = (w >= n) ? n - 1 : w; ++ p += w; ++ n -= w; + break; -+ case '\\': -+ if (*(s + 1)) -+ p += sprintf(p, "%c", strip(*++s)); + default: + *p = strip(*s); ++p; ++ --n; + break; + } + s++; @@ -139,7 +142,7 @@ void *************** *** 216,221 **** ---- 317,326 ---- +--- 320,329 ---- #endif @@ -152,7 +155,7 @@ fprintf(cp_err, "main: Internal Error: jump to zero\n"); *************** *** 236,241 **** ---- 341,353 ---- +--- 344,356 ---- ARCHsize = 1; #endif /* PARALLEL_ARCH */ @@ -168,7 +171,7 @@ #endif *************** *** 472,478 **** ---- 584,594 ---- +--- 587,597 ---- # ifdef HAS_UNIX_SIGS /* Set up (void) signal handling */ if (!ft_batchmode) { @@ -182,7 +185,7 @@ (void) signal(SIGTSTP, sigstop); *************** *** 668,674 **** ---- 784,794 ---- +--- 787,797 ---- } else { (void) setjmp(jbuf); cp_interactive = true; @@ -196,7 +199,7 @@ # else /* if BATCH */ *************** *** 708,714 **** ---- 828,838 ---- +--- 831,841 ---- /* Nutmeg "main" */ (void) setjmp(jbuf); cp_interactive = true; diff --git a/cad/cider/files/patch-bm b/cad/cider/files/patch-bm new file mode 100644 index 000000000000..d750cfd15b6b --- /dev/null +++ b/cad/cider/files/patch-bm @@ -0,0 +1,16 @@ +--- cider/common/src/lib/support/erfc.c.orig Sat Jan 29 19:29:27 1994 ++++ cider/common/src/lib/support/erfc.c Tue Oct 24 12:23:09 2000 +@@ -10,6 +10,7 @@ + + /* erfc computes the erfc(x) the code is from sedan's derfc.f */ + ++#ifdef HAS_NO_ERFC + double erfc ( x ) + double x; + { +@@ -46,4 +47,4 @@ + return( 1.0 - sum2 ); + } + } +- ++#endif |