Annotation of 43BSDReno/sys/nfs/TEST/unix-tests/getopt.c, revision 1.1.1.1

1.1       root        1: #ifndef lint
                      2: static char NFSTestID[] = "@(#)getopt.c        1.1 Lachman ONC Test Suite source";
                      3: #endif /* lint */
                      4: /*
                      5:  * Here's something you've all been waiting for:  the AT&T public domain
                      6:  * source for getopt(3).  It is the code which was given out at the 1985
                      7:  * UNIFORUM conference in Dallas.  I obtained it by electronic mail
                      8:  * directly from AT&T.  The people there assure me that it is indeed
                      9:  * in the public domain.
                     10:  * 
                     11:  * There is no manual page.  That is because the one they gave out at
                     12:  * UNIFORUM was slightly different from the current System V Release 2
                     13:  * manual page.  The difference apparently involved a note about the
                     14:  * famous rules 5 and 6, recommending using white space between an option
                     15:  * and its first argument, and not grouping options that have arguments.
                     16:  * Getopt itself is currently lenient about both of these things White
                     17:  * space is allowed, but not mandatory, and the last option in a group can
                     18:  * have an argument.  That particular version of the man page evidently
                     19:  * has no official existence, and my source at AT&T did not send a copy.
                     20:  * The current SVR2 man page reflects the actual behavor of this getopt.
                     21:  * However, I am not about to post a copy of anything licensed by AT&T.
                     22:  */
                     23: 
                     24: 
                     25: /*LINTLIBRARY*/
                     26: #define NULL   0
                     27: #define EOF    (-1)
                     28: #define ERR(s, c)      if(opterr){\
                     29:        extern int write();\
                     30:        char errbuf[2];\
                     31:        errbuf[0] = c; errbuf[1] = '\n';\
                     32:        (void) write(2, argv[0], (unsigned)strlen(argv[0]));\
                     33:        (void) write(2, s, (unsigned)strlen(s));\
                     34:        (void) write(2, errbuf, 2);}
                     35: 
                     36: #ifdef SVR3
                     37: extern char *strchr();
                     38: #else
                     39: extern char *index();
                     40: #endif
                     41: 
                     42: int    opterr = 1;
                     43: int    optind = 1;
                     44: int    optopt;
                     45: char   *optarg;
                     46: 
                     47: int
                     48: getopt(argc, argv, opts)
                     49: int    argc;
                     50: char   **argv, *opts;
                     51: {
                     52:        static int sp = 1;
                     53:        register int c;
                     54:        register char *cp;
                     55: 
                     56:        if(sp == 1)
                     57:                if(optind >= argc ||
                     58:                   argv[optind][0] != '-' || argv[optind][1] == '\0')
                     59:                        return(EOF);
                     60:                else if(strcmp(argv[optind], "--") == NULL) {
                     61:                        optind++;
                     62:                        return(EOF);
                     63:                }
                     64:        optopt = c = argv[optind][sp];
                     65: #ifdef SVR3
                     66:        if(c == ':' || (cp=strchr(opts, c)) == NULL) {
                     67: #else
                     68:        if(c == ':' || (cp=index(opts, c)) == NULL) {
                     69: #endif
                     70:                ERR(": illegal option -- ", c);
                     71:                if(argv[optind][++sp] == '\0') {
                     72:                        optind++;
                     73:                        sp = 1;
                     74:                }
                     75:                return('?');
                     76:        }
                     77:        if(*++cp == ':') {
                     78:                if(argv[optind][sp+1] != '\0')
                     79:                        optarg = &argv[optind++][sp+1];
                     80:                else if(++optind >= argc) {
                     81:                        ERR(": option requires an argument -- ", c);
                     82:                        sp = 1;
                     83:                        return('?');
                     84:                } else
                     85:                        optarg = argv[optind++];
                     86:                sp = 1;
                     87:        } else {
                     88:                if(argv[optind][++sp] == '\0') {
                     89:                        sp = 1;
                     90:                        optind++;
                     91:                }
                     92:                optarg = NULL;
                     93:        }
                     94:        return(c);
                     95: }
                     96: 
                     97: #include       <stdio.h>
                     98: 
                     99: main(ac, av)
                    100: char   **av;
                    101: {
                    102:        register int    i;
                    103:        int     first = 1;
                    104:        int     error = 0;
                    105:        char    buf[BUFSIZ];
                    106:        char    line[BUFSIZ];
                    107:        extern char     *optarg;
                    108:        extern int      optind;
                    109: 
                    110:        if (ac == 1) {
                    111:                fprintf(stderr, "usage:  getopt legal-args $*\n");
                    112:                exit(2);
                    113:        }
                    114: 
                    115:        line[0] = '\0';
                    116:        while ((i = getopt(ac - 1, &av[1], av[1])) != EOF) {
                    117:                if (i == '?')
                    118:                        exit(2);
                    119: 
                    120:                if (first) {
                    121:                        first = 0;
                    122:                        sprintf(buf, "-%c", i & 0xff);
                    123:                }
                    124:                else
                    125:                        sprintf(buf, " -%c", i & 0xff);
                    126:                strcat(line, buf);
                    127:                if (optarg) {
                    128:                        sprintf(buf, " %s", optarg);
                    129:                        strcat(line, buf);
                    130:                }
                    131:        }
                    132: 
                    133:        if (first)
                    134:                strcat(line, "--");
                    135:        else
                    136:                strcat(line, " --");
                    137: 
                    138:        optind++;
                    139:        for (; optind < ac; optind++) {
                    140:                sprintf(buf, " %s", av[optind]);
                    141:                strcat(line, buf);
                    142:        }
                    143:        printf("%s\n", line);
                    144:        exit(0);
                    145: }

unix.superglobalmegacorp.com

This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.