summaryrefslogtreecommitdiff
path: root/ioq3-r437/src/tools/lcc/cpp/getopt.c
diff options
context:
space:
mode:
authorTim Angus <tim@ngus.net>2005-12-10 02:56:06 +0000
committerTim Angus <tim@ngus.net>2005-12-10 02:56:06 +0000
commit08446c16acbbb9a9d12fccb21e27cfa29d076e77 (patch)
tree1dc6a6fd6c9baa4a56e01abb84601368b5de80a1 /ioq3-r437/src/tools/lcc/cpp/getopt.c
parent7ba4af6168b726759d45b8d9d95dbebe26aa3186 (diff)
* Branch upstream ioq3-r437 into trunk
Diffstat (limited to 'ioq3-r437/src/tools/lcc/cpp/getopt.c')
-rw-r--r--ioq3-r437/src/tools/lcc/cpp/getopt.c53
1 files changed, 53 insertions, 0 deletions
diff --git a/ioq3-r437/src/tools/lcc/cpp/getopt.c b/ioq3-r437/src/tools/lcc/cpp/getopt.c
new file mode 100644
index 00000000..abcb35f8
--- /dev/null
+++ b/ioq3-r437/src/tools/lcc/cpp/getopt.c
@@ -0,0 +1,53 @@
+#include <stdio.h>
+#include <string.h>
+#define EPR fprintf(stderr,
+#define ERR(str, chr) if(opterr){EPR "%s%c\n", str, chr);}
+int opterr = 1;
+int optind = 1;
+int optopt;
+char *optarg;
+
+int
+getopt (int argc, char *const argv[], const char *opts)
+{
+ static int sp = 1;
+ int c;
+ char *cp;
+
+ if (sp == 1) {
+ if (optind >= argc ||
+ argv[optind][0] != '-' || argv[optind][1] == '\0')
+ return -1;
+ else if (strcmp(argv[optind], "--") == 0) {
+ optind++;
+ return -1;
+ }
+ }
+ optopt = c = argv[optind][sp];
+ if (c == ':' || (cp=strchr(opts, c)) == 0) {
+ ERR (": illegal option -- ", c);
+ if (argv[optind][++sp] == '\0') {
+ optind++;
+ sp = 1;
+ }
+ return '?';
+ }
+ if (*++cp == ':') {
+ if (argv[optind][sp+1] != '\0')
+ optarg = &argv[optind++][sp+1];
+ else if (++optind >= argc) {
+ ERR (": option requires an argument -- ", c);
+ sp = 1;
+ return '?';
+ } else
+ optarg = argv[optind++];
+ sp = 1;
+ } else {
+ if (argv[optind][++sp] == '\0') {
+ sp = 1;
+ optind++;
+ }
+ optarg = 0;
+ }
+ return c;
+}