aboutsummaryrefslogtreecommitdiff
path: root/cad/cider
diff options
context:
space:
mode:
authorKevin Lo <kevlo@FreeBSD.org>2000-10-28 16:13:06 +0000
committerKevin Lo <kevlo@FreeBSD.org>2000-10-28 16:13:06 +0000
commitfe660b35732a2be7063ead8ee6a67b2b2f14f55d (patch)
tree21ffa5a79690d43748091200a1ba2040c7b52bf3 /cad/cider
parent20eb6aadc91b62548cbaf4031b6706ac4e68438c (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/Makefile1
-rw-r--r--cad/cider/files/patch-ad27
-rw-r--r--cad/cider/files/patch-bc27
-rw-r--r--cad/cider/files/patch-bm16
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