* Copyright (c) 1987 Regents of the University of California.
* %sccs.include.redist.c%
#if defined(LIBC_SCCS) && !defined(lint)
static char sccsid
[] = "@(#)getopt.c 4.13 (Berkeley) %G%";
#endif /* LIBC_SCCS and not lint */
* get option letter from argument vector
int opterr
= 1, /* if error message should be printed */
optind
= 1, /* index into parent argv vector */
optopt
; /* character checked for validity */
char *optarg
; /* argument associated with option */
getopt(nargc
, nargv
, ostr
)
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
]) != '-') {
if (place
[1] && *++place
== '-') { /* found "--" */
} /* option letter okay? */
if ((optopt
= (int)*place
++) == (int)':' ||
!(oli
= index(ostr
, optopt
))) {
* if the user didn't specify '-' as an option,
if (!(p
= rindex(*nargv
, '/')))
(void)fprintf(stderr
, "%s: illegal option -- %c\n",
if (*++oli
!= ':') { /* don't need argument */
else { /* need an argument */
if (*place
) /* no white space */
else if (nargc
<= ++optind
) { /* no arg */
if (!(p
= rindex(*nargv
, '/')))
"%s: option requires an argument -- %c\n",
return(optopt
); /* dump back option letter */