/* $NetBSD: getoldopt.c,v 1.6 2005/12/01 03:00:01 minskim Exp $ */ /* * Plug-compatible replacement for getopt() for parsing tar-like * arguments. If the first argument begins with "-", it uses getopt; * otherwise, it uses the old rules used by tar, dump, and ps. * * Written 25 August 1985 by John Gilmore (ihnp4!hoptoad!gnu) and placed * in the Public Domain for your edification and enjoyment. */ #if HAVE_CONFIG_H #include "config.h" #endif #if HAVE_NBTOOL_CONFIG_H #include "nbtool_config.h" #endif #include #if HAVE_SYS_CDEFS_H #include #endif #if !defined(lint) __RCSID("$NetBSD: getoldopt.c,v 1.6 2005/12/01 03:00:01 minskim Exp $"); #endif /* not lint */ #if HAVE_NBTOOL_CONFIG_H #include "compat_getopt.h" #else #if HAVE_GETOPT_H #include #endif #endif #if HAVE_STDIO_H #include #endif #if HAVE_STRING_H #include #endif #if HAVE_STDLIB_H #include #endif #if HAVE_UNISTD_H #include #endif #if HAVE_SYS_STAT_H #include #endif #include "pax.h" #include "extern.h" int getoldopt(int argc, char **argv, const char *optstring, struct option *longopts, int *idx) { static char *key; /* Points to next keyletter */ static char use_getopt; /* !=0 if argv[1][0] was '-' */ char c; char *place; optarg = NULL; if (key == NULL) { /* First time */ if (argc < 2) return -1; key = argv[1]; if (*key == '-') use_getopt++; else optind = 2; } c = '\0'; if (!use_getopt) { c = *key++; if (c == '\0') { key--; use_getopt = 1; } } if (use_getopt) { if (longopts != NULL) { return getopt_long(argc, argv, optstring, longopts, idx); } else { return getopt(argc, argv, optstring); } } place = strchr(optstring, c); if (place == NULL || c == ':') { fprintf(stderr, "%s: unknown option %c\n", argv[0], c); return('?'); } place++; if (*place == ':') { if (optind < argc) { optarg = argv[optind]; optind++; } else { fprintf(stderr, "%s: %c argument missing\n", argv[0], c); return('?'); } } return(c); }