minor fixes for safecopy & safemap tests
[minix.git] / commands / pax / getoldopt.c
blobe077298c9b316d3e901ec1e960da66755dbe1d71
1 /* $OpenBSD: getoldopt.c,v 1.4 2000/01/22 20:24:51 deraadt Exp $ */
2 /* $NetBSD: getoldopt.c,v 1.3 1995/03/21 09:07:28 cgd Exp $ */
4 /*-
5 * Plug-compatible replacement for getopt() for parsing tar-like
6 * arguments. If the first argument begins with "-", it uses getopt;
7 * otherwise, it uses the old rules used by tar, dump, and ps.
9 * Written 25 August 1985 by John Gilmore (ihnp4!hoptoad!gnu) and placed
10 * in the Pubic Domain for your edification and enjoyment.
14 #include <sys/types.h>
15 #include <sys/stat.h>
16 #include <stdio.h>
17 #include <string.h>
18 #include <unistd.h>
20 #include "pax.h"
21 #include "extern.h"
23 int
24 getoldopt(int argc, char **argv, const char *optstring)
26 static char *key; /* Points to next keyletter */
27 static char use_getopt; /* !=0 if argv[1][0] was '-' */
28 char c;
29 char *place;
31 optarg = NULL;
33 if (key == NULL) { /* First time */
34 if (argc < 2) return EOF;
35 key = argv[1];
36 if (*key == '-')
37 use_getopt++;
38 else
39 optind = 2;
42 if (use_getopt)
43 return getopt(argc, argv, optstring);
45 c = *key++;
46 if (c == '\0') {
47 key--;
48 return EOF;
50 place = strchr(optstring, c);
52 if (place == NULL || c == ':') {
53 fprintf(stderr, "%s: unknown option %c\n", argv[0], c);
54 return('?');
57 place++;
58 if (*place == ':') {
59 if (optind < argc) {
60 optarg = argv[optind];
61 optind++;
62 } else {
63 fprintf(stderr, "%s: %c argument missing\n",
64 argv[0], c);
65 return('?');
69 return(c);