* Copyright (c) 1985 Regents of the University of California.
* All rights reserved. The Berkeley software License Agreement
* specifies the terms and conditions for redistribution.
static char sccsid
[] = "@(#)getopt.c 4.1 (Berkeley) %G%";
* get option letter from argument vector
int opterr
= 1, /* useless, never set or used */
optind
= 1, /* index into parent argv vector */
optopt
; /* character checked for validity */
char *optarg
; /* argument associated with option */
#define tell(s) fputs(*nargv,stderr);fputs(s,stderr); \
fputc(optopt,stderr);fputc('\n',stderr);return(BADCH);
static char *place
= EMSG
; /* option letter processing */
register char *oli
; /* option letter list index */
if(!*place
) { /* update scanning pointer */
if(optind
>= nargc
|| *(place
= nargv
[optind
]) != '-' || !*++place
) return(EOF
);
if (*place
== '-') { /* found "--" */
} /* option letter okay? */
if ((optopt
= (int)*place
++) == (int)':' || !(oli
= index(ostr
,optopt
))) {
tell(": illegal option -- ");
if (*++oli
!= ':') { /* don't need argument */
else { /* need an argument */
if (*place
) optarg
= place
; /* no white space */
else if (nargc
<= ++optind
) { /* no arg */
tell(": option requires an argument -- ");
else optarg
= nargv
[optind
]; /* white space */
return(optopt
); /* dump back option letter */