diff options
author | Todd C. Miller <millert@cvs.openbsd.org> | 1997-04-02 17:48:54 +0000 |
---|---|---|
committer | Todd C. Miller <millert@cvs.openbsd.org> | 1997-04-02 17:48:54 +0000 |
commit | 7e2116a14a40c7c52f7a2dbc31c5d2ec7ff2d528 (patch) | |
tree | 6e086f0f97e3a9e4ef0bfac93d9e74ae56ee5041 | |
parent | 374183326222a4c5006d9d68869416f49675611b (diff) |
opt_add() needs to make a copy of the input string since it modifies
it and new compilers don't let you write to constant strings.
Problem (core dump when using -o) noted by Felix Schroeter.
-rw-r--r-- | bin/pax/options.c | 10 |
1 files changed, 8 insertions, 2 deletions
diff --git a/bin/pax/options.c b/bin/pax/options.c index 66d565fc341..eccfd4dbe91 100644 --- a/bin/pax/options.c +++ b/bin/pax/options.c @@ -1,4 +1,4 @@ -/* $OpenBSD: options.c,v 1.17 1997/03/26 01:14:13 millert Exp $ */ +/* $OpenBSD: options.c,v 1.18 1997/04/02 17:48:53 millert Exp $ */ /* $NetBSD: options.c,v 1.6 1996/03/26 23:54:18 mrg Exp $ */ /*- @@ -42,7 +42,7 @@ #if 0 static char sccsid[] = "@(#)options.c 8.2 (Berkeley) 4/18/94"; #else -static char rcsid[] = "$OpenBSD: options.c,v 1.17 1997/03/26 01:14:13 millert Exp $"; +static char rcsid[] = "$OpenBSD: options.c,v 1.18 1997/04/02 17:48:53 millert Exp $"; #endif #endif /* not lint */ @@ -1270,6 +1270,10 @@ opt_add(str) paxwarn(0, "Invalid option name"); return(-1); } + if ((str = strdup(str)) == NULL) { + paxwarn(0, "Unable to allocate space for option list"); + return(-1); + } frpt = endpt = str; /* @@ -1282,10 +1286,12 @@ opt_add(str) *endpt = '\0'; if ((pt = strchr(frpt, '=')) == NULL) { paxwarn(0, "Invalid options format"); + free(str); return(-1); } if ((opt = (OPLIST *)malloc(sizeof(OPLIST))) == NULL) { paxwarn(0, "Unable to allocate space for option list"); + free(str); return(-1); } *pt++ = '\0'; |