/* * Small reimplementation of getopt(). */ #include "config.h" #include #include #include #ifndef HAVE_GETOPT char *minioptarg = NULL; int minioptind = 0; int miniopterr = 1; int minioptopt = 0; /* * Minimalist getopt() clone, which handles short options only and doesn't * permute argv[]. */ int minigetopt(int argc, char **argv, char *optstring) { static int nextchar = 0; int optchar; int i; if ((0 == minioptind) && (argc > 0)) minioptind++; if ((nextchar > 0) && (0 == argv[minioptind][nextchar])) { minioptind++; nextchar = 0; } if (minioptind >= argc) return -1; /* * End of options if arg doesn't start with "-" */ if (argv[minioptind][0] != '-') return -1; /* * End of options if arg is just "-" */ if (0 == argv[minioptind][1]) return -1; /* * End of options if arg is "--", but don't include the "--" in the * non-option arguments */ if (('-' == argv[minioptind][1]) && (0 == argv[minioptind][2])) { minioptind++; return -1; } if (0 == nextchar) nextchar = 1; optchar = argv[minioptind][nextchar++]; for (i = 0; optstring[i] != 0 && optstring[i] != optchar; i++) { } if (0 == optstring[i]) { minioptopt = optchar; if (miniopterr) fprintf(stderr, "%s: invalid option -- %c\n", argv[0], optchar); return '?'; } if (optstring[i + 1] != ':') { minioptarg = NULL; return optchar; } /* * At this point we've got an option that takes an argument. */ /* * Next character isn't 0, so the argument is within this array * element (i.e. "-dFOO"). */ if (argv[minioptind][nextchar] != 0) { minioptarg = &(argv[minioptind][nextchar]); nextchar = 0; minioptind++; return optchar; } /* * Argument is in the next array element (i.e. "-d FOO"). */ nextchar = 0; minioptind++; if (minioptind >= argc) { fprintf(stderr, "%s: option `-%c' requires an argument\n", argv[0], optchar); return ':'; } minioptarg = argv[minioptind++]; return optchar; } #endif /* HAVE_GETOPT */ /* EOF */