diff options
Diffstat (limited to 'src/cmd')
-rw-r--r-- | src/cmd/mk/archive.c | 4 | ||||
-rw-r--r-- | src/cmd/mk/graph.c | 2 | ||||
-rw-r--r-- | src/cmd/mk/mk.c | 4 | ||||
-rw-r--r-- | src/cmd/mk/unix.c | 11 |
4 files changed, 12 insertions, 9 deletions
diff --git a/src/cmd/mk/archive.c b/src/cmd/mk/archive.c index 14d2082d..8edfdddc 100644 --- a/src/cmd/mk/archive.c +++ b/src/cmd/mk/archive.c @@ -17,7 +17,7 @@ struct ar_hdr }; #define SAR_HDR (SARNAME+44) -static int dolong; +static int dolong = 1; static void atimes(char *); static char *split(char*, char**); @@ -154,7 +154,7 @@ atimes(char *ar) goto skip; }else if(strings && h.name[0]=='/' && isdigit(h.name[1])){ i = strtol(h.name+1, &p, 10); - if(*p != ' ' || strlen(strings) < i) + if(*p != ' ' || i >= strlen(strings)) goto skip; p = strings+i; for(; *p && *p != '/'; p++) diff --git a/src/cmd/mk/graph.c b/src/cmd/mk/graph.c index 58529259..fdb02881 100644 --- a/src/cmd/mk/graph.c +++ b/src/cmd/mk/graph.c @@ -180,7 +180,7 @@ dumpn(char *s, Node *n) char buf[1024]; Arc *a; - sprint(buf, "%s ", (*s == ' ')? s:""); + snprint(buf, sizeof buf, "%s ", (*s == ' ')? s:""); Bprint(&bout, "%s%s@%ld: time=%ld flags=0x%x next=%ld\n", s, n->name, n, n->time, n->flags, n->next); for(a = n->prereqs; a; a = a->next) diff --git a/src/cmd/mk/mk.c b/src/cmd/mk/mk.c index 37eb3511..9ab4c538 100644 --- a/src/cmd/mk/mk.c +++ b/src/cmd/mk/mk.c @@ -198,7 +198,7 @@ pcmp(char *prog, char *p, char *q) int pid; Bflush(&bout); - sprint(buf, "%s '%s' '%s'\n", prog, p, q); + snprint(buf, sizeof buf, "%s '%s' '%s'\n", prog, p, q); pid = pipecmd(buf, 0, 0); while(waitup(-3, &pid) >= 0) ; @@ -214,7 +214,7 @@ outofdate(Node *node, Arc *arc, int eval) str = 0; if(arc->prog){ - sprint(buf, "%s%c%s", node->name, 0377, arc->n->name); + snprint(buf, sizeof buf, "%s%c%s", node->name, 0377, arc->n->name); sym = symlook(buf, S_OUTOFDATE, 0); if(sym == 0 || eval){ if(sym == 0) diff --git a/src/cmd/mk/unix.c b/src/cmd/mk/unix.c index 8b7e9cb8..00bee01e 100644 --- a/src/cmd/mk/unix.c +++ b/src/cmd/mk/unix.c @@ -47,15 +47,15 @@ exportenv(Envy *e) { int i; char **p; - char buf[4096]; + static char buf[16384]; p = 0; for(i = 0; e->name; e++, i++) { p = (char**) Realloc(p, (i+2)*sizeof(char*)); if(e->values) - sprint(buf, "%s=%s", e->name, wtos(e->values, IWS)); + snprint(buf, sizeof buf, "%s=%s", e->name, wtos(e->values, IWS)); else - sprint(buf, "%s=", e->name); + snprint(buf, sizeof buf, "%s=", e->name); p[i] = strdup(buf); } p[i] = 0; @@ -91,6 +91,8 @@ expunge(int pid, char *msg) kill(pid, SIGHUP); } +int mypid; + int execsh(char *args, char *cmd, Bufblock *buf, Envy *e) { @@ -102,6 +104,7 @@ execsh(char *args, char *cmd, Bufblock *buf, Envy *e) Exit(); } pid = fork(); + mypid = getpid(); if(pid < 0){ mkperror("mk fork"); Exit(); @@ -225,7 +228,7 @@ static struct SIGFPE, "sys: fp: fptrap", SIGPIPE, "sys: write on closed pipe", SIGILL, "sys: trap: illegal instruction", - SIGSEGV, "sys: segmentation violation", +// SIGSEGV, "sys: segmentation violation", 0, 0 }; |