summaryrefslogtreecommitdiff
path: root/lang
diff options
context:
space:
mode:
Diffstat (limited to 'lang')
-rw-r--r--lang/focal/distinfo10
-rw-r--r--lang/focal/patches/patch-aa86
-rw-r--r--lang/focal/patches/patch-ab17
-rw-r--r--lang/focal/patches/patch-ac4
-rw-r--r--lang/focal/patches/patch-focal1_c24
-rw-r--r--lang/focal/patches/patch-focal3_c66
6 files changed, 198 insertions, 9 deletions
diff --git a/lang/focal/distinfo b/lang/focal/distinfo
index 788687d4b3c..15d4dd04f7f 100644
--- a/lang/focal/distinfo
+++ b/lang/focal/distinfo
@@ -1,8 +1,10 @@
-$NetBSD: distinfo,v 1.4 2010/04/29 00:22:02 dholland Exp $
+$NetBSD: distinfo,v 1.5 2012/05/31 23:37:57 dholland Exp $
SHA1 (focal.tar.gz) = 704d1411365085fb47ff25c1a77ae1f8e7fa601e
RMD160 (focal.tar.gz) = 6b06cc08b2761035c315ae13b80d64a5e7a6004b
Size (focal.tar.gz) = 12561 bytes
-SHA1 (patch-aa) = 632a2ff83f744865a154712ce31092e1435af6f2
-SHA1 (patch-ab) = b2795472241ef1d1cc554e7c13bf35dc4b39b330
-SHA1 (patch-ac) = 17d1d5e2895d45c76782dfa79b97f583efa5346d
+SHA1 (patch-aa) = 9e761e135665dad02b8cc700d80bf4eba69a0e7d
+SHA1 (patch-ab) = b4f0c53188dc67fa890da6093d5d5431df3b7efc
+SHA1 (patch-ac) = b56fe36efbcb15f6a5454943a40871683d0c1e0a
+SHA1 (patch-focal1_c) = 3957cde40ea86a218aea8411623d4bd033df9dbe
+SHA1 (patch-focal3_c) = 1624c53612707f71f628a74bf6bc186bfff0f96b
diff --git a/lang/focal/patches/patch-aa b/lang/focal/patches/patch-aa
index 66f4c973e38..63257ca70da 100644
--- a/lang/focal/patches/patch-aa
+++ b/lang/focal/patches/patch-aa
@@ -1,4 +1,11 @@
-$NetBSD: patch-aa,v 1.2 2010/04/29 00:22:02 dholland Exp $
+$NetBSD: patch-aa,v 1.3 2012/05/31 23:37:57 dholland Exp $
+
+- place a big comment within a comment (just within a false ifdef is
+not sufficient)
+- do not use gets()
+- use ctype.h functions correctly
+- avoid symbol conflict with getline()
+- don't use implicit int
--- focal0.c.orig 1995-04-17 13:03:43.000000000 +0000
+++ focal0.c
@@ -18,7 +25,59 @@ $NetBSD: patch-aa,v 1.2 2010/04/29 00:22:02 dholland Exp $
#include "focal.h"
#ifdef vms
-@@ -649,7 +651,7 @@ register int c;
+@@ -66,6 +68,24 @@ int intflag; /* Interrupt flag */
+
+ struct sym *sym[N_HASH + 1]; /* Symbol table */
+
++static char *
++dogets(char *buf, size_t len)
++{
++ char *ret;
++
++ ret = fgets(buf, len, stdin);
++ if (ret != NULL) {
++ len = strlen(buf);
++ if (len > 0 && buf[len-1] == '\n') {
++ buf[--len] = '\0';
++ }
++ if (len > 0 && buf[len-1] == '\r') {
++ buf[--len] = '\0';
++ }
++ }
++ return ret;
++}
++
+ int main()
+ {
+ register int c;
+@@ -86,7 +106,7 @@ int main()
+ catchcc();
+ for (;;) {
+ putchar('*');
+- if (gets(cbuf) == NULL) {
++ if (dogets(cbuf, sizeof(cbuf)) == NULL) {
+ putchar('\n');
+ break;
+ }
+@@ -205,7 +225,7 @@ loop:
+ popdo();
+ goto loop;
+ }
+- while (isalpha(*ctp))
++ while (isalpha((unsigned char)*ctp))
+ ++ctp;
+ if (isupper(c))
+ c = tolower(c);
+@@ -427,7 +447,7 @@ void ask()
+ --ctp;
+ sp = getsym();
+ printf(": ");
+- if (gets(abuf) == NULL) {
++ if (dogets(abuf, sizeof(abuf)) == NULL) {
+ putchar('\n');
+ diag("EOF in ask");
+ }
+@@ -649,11 +669,11 @@ register int c;
}
@@ -27,3 +86,26 @@ $NetBSD: patch-aa,v 1.2 2010/04/29 00:22:02 dholland Exp $
register char *cp;
register FILE *fp;
{
+- register c;
++ register int c;
+
+ while ((c=getc(fp))!=EOF && c!='\n')
+ *cp++ = c;
+@@ -667,7 +687,7 @@ register FILE *fp;
+ void type()
+ {
+ register char *fmt;
+- register c;
++ register int c;
+ static char fmtb[20];
+ static int ifmtb = 1;
+ int x, y;
+@@ -724,7 +744,7 @@ FILE *fp;
+ {
+ struct lno lno;
+ register struct line *lp;
+- register tgroup, lgroup;
++ register int tgroup, lgroup;
+
+ if (lnop == NULL) {
+ lno.ln_type = LN_ALL;
diff --git a/lang/focal/patches/patch-ab b/lang/focal/patches/patch-ab
index 18e2eeec29e..2b06579f476 100644
--- a/lang/focal/patches/patch-ab
+++ b/lang/focal/patches/patch-ab
@@ -1,7 +1,20 @@
-$NetBSD: patch-ab,v 1.2 2010/04/29 00:22:02 dholland Exp $
+$NetBSD: patch-ab,v 1.3 2012/05/31 23:37:57 dholland Exp $
+
+- use ctype.h functions correctly
+- avoid symbol name conflict with getline()
+- the name in struct dirent is null-terminated, don't try to bound it
--- focal2.c.orig 1995-04-17 13:03:46.000000000 +0000
+++ focal2.c
+@@ -49,7 +49,7 @@ void library()
+ c = getnb();
+ if (c!='c' && c!='s' && c!='l' && c!='d')
+ diag("Bad library command");
+- while (isalpha(*ctp))
++ while (isalpha((unsigned char)*ctp))
+ ++ctp;
+ while ((d = *ctp)==' ' || d=='\t')
+ ++ctp;
@@ -71,7 +71,7 @@ void library()
}
line = NULL;
@@ -16,7 +29,7 @@ $NetBSD: patch-ab,v 1.2 2010/04/29 00:22:02 dholland Exp $
|| strcmp(de->d_name, "..") == 0)
continue;
- printf("%.*s\n", de->d_reclen, de->d_name);
-+ printf("%.*s\n", de->d_namlen, de->d_name);
++ printf("%s\n", de->d_name);
}
closedir(dp);
#else
diff --git a/lang/focal/patches/patch-ac b/lang/focal/patches/patch-ac
index 1b79e633cf0..5a0cdf4c7be 100644
--- a/lang/focal/patches/patch-ac
+++ b/lang/focal/patches/patch-ac
@@ -1,4 +1,6 @@
-$NetBSD: patch-ac,v 1.1 2010/04/29 00:22:02 dholland Exp $
+$NetBSD: patch-ac,v 1.2 2012/05/31 23:37:57 dholland Exp $
+
+- avoid symbol name conflict with getline()
--- proto.h~ 1995-04-17 13:03:41.000000000 +0000
+++ proto.h
diff --git a/lang/focal/patches/patch-focal1_c b/lang/focal/patches/patch-focal1_c
new file mode 100644
index 00000000000..8031d404db3
--- /dev/null
+++ b/lang/focal/patches/patch-focal1_c
@@ -0,0 +1,24 @@
+$NetBSD: patch-focal1_c,v 1.1 2012/05/31 23:37:57 dholland Exp $
+
+- don't use implicit int
+
+--- focal1.c~ 1995-04-17 13:03:45.000000000 +0000
++++ focal1.c
+@@ -146,7 +146,7 @@ term()
+ struct sym *
+ lookup(id, type, subs)
+ char *id;
+-register type;
++register int type;
+ int subs;
+ {
+ register struct sym *sp;
+@@ -167,7 +167,7 @@ int subs;
+ struct sym *
+ getsym()
+ {
+- register c;
++ register int c;
+ char id[NID];
+ register char *cp;
+ register struct sym *sp;
diff --git a/lang/focal/patches/patch-focal3_c b/lang/focal/patches/patch-focal3_c
new file mode 100644
index 00000000000..86118cbee81
--- /dev/null
+++ b/lang/focal/patches/patch-focal3_c
@@ -0,0 +1,66 @@
+$NetBSD: patch-focal3_c,v 1.1 2012/05/31 23:37:57 dholland Exp $
+
+- don't use implicit int
+- use ctype.h functions correctly
+- fix accidental use of bitwise or in logical comparison
+- return characters 0..255 from getnb() to avoid incorrect calls to
+ctype.h functions elsewhere
+
+--- focal3.c~ 1995-04-17 13:03:47.000000000 +0000
++++ focal3.c
+@@ -29,9 +29,9 @@ FILE *fp;
+ */
+ void getlno(lnop, c)
+ register struct lno *lnop;
+-register c;
++register int c;
+ {
+- register gn, ln;
++ register int gn, ln;
+ static char badlno[] = "Bad line or group number";
+
+ if (c < 0)
+@@ -42,7 +42,7 @@ register c;
+ return;
+ }
+ if (c=='A' || c=='a') {
+- while (isalpha(*ctp))
++ while (isalpha((unsigned char)*ctp))
+ ++ctp;
+ lnop->ln_type = LN_ALL;
+ return;
+@@ -64,7 +64,7 @@ register c;
+ lnop->ln_type = LN_GRP;
+ return;
+ }
+- if (ln<1 | ln>99)
++ if (ln<1 || ln>99)
+ diag(badlno);
+ lnop->ln_gno = gn;
+ lnop->ln_lno = ln;
+@@ -78,9 +78,9 @@ register c;
+ * Return the number read.
+ */
+ int getnum(c)
+-register c;
++register int c;
+ {
+- register n;
++ register int n;
+
+ n = 0;
+ while (isdigit(c)) {
+@@ -152,11 +152,11 @@ char *s;
+ */
+ int getnb()
+ {
+- register c;
++ register int c;
+
+ while ((c = *ctp++)==' ' || c=='\t')
+ ;
+- return (c);
++ return ((int)(unsigned char)c);
+ }
+ /*
+ * drand48