1999-08-28 23:23:38 +00:00
|
|
|
.\" $FreeBSD$
|
|
|
|
.\"
|
2011-01-26 18:43:15 +00:00
|
|
|
.Dd January 26, 2011
|
1993-07-26 22:22:37 +00:00
|
|
|
.Dt GETOPT 1
|
|
|
|
.Os
|
|
|
|
.Sh NAME
|
|
|
|
.Nm getopt
|
|
|
|
.Nd parse command options
|
|
|
|
.Sh SYNOPSIS
|
1999-04-04 13:49:10 +00:00
|
|
|
.Nm args=\`getopt Ar optstring $*\`
|
|
|
|
; errcode=$?; set \-\- $args
|
1993-07-26 22:22:37 +00:00
|
|
|
.Sh DESCRIPTION
|
2002-04-19 23:44:58 +00:00
|
|
|
The
|
|
|
|
.Nm
|
|
|
|
utility is used to break up options in command lines for easy parsing by
|
1993-07-26 22:22:37 +00:00
|
|
|
shell procedures, and to check for legal options.
|
1996-10-22 21:56:11 +00:00
|
|
|
.Ar Optstring
|
1993-07-26 22:22:37 +00:00
|
|
|
is a string of recognized option letters (see
|
2001-08-10 17:35:21 +00:00
|
|
|
.Xr getopt 3 ) ;
|
1993-07-26 22:22:37 +00:00
|
|
|
if a letter is followed by a colon, the option
|
|
|
|
is expected to have an argument which may or may not be
|
|
|
|
separated from it by white space.
|
|
|
|
The special option
|
1996-10-22 21:56:11 +00:00
|
|
|
.Ql \-\-
|
1993-07-26 22:22:37 +00:00
|
|
|
is used to delimit the end of the options.
|
2002-04-19 23:44:58 +00:00
|
|
|
The
|
|
|
|
.Nm
|
|
|
|
utility will place
|
1996-10-22 21:56:11 +00:00
|
|
|
.Ql \-\-
|
1993-07-26 22:22:37 +00:00
|
|
|
in the arguments at the end of the options,
|
|
|
|
or recognize it if used explicitly.
|
|
|
|
The shell arguments
|
|
|
|
(\fB$1 $2\fR ...) are reset so that each option is
|
|
|
|
preceded by a
|
1996-10-22 21:56:11 +00:00
|
|
|
.Ql \-
|
1993-07-26 22:22:37 +00:00
|
|
|
and in its own shell argument;
|
|
|
|
each option argument is also in its own shell argument.
|
2005-01-18 13:43:56 +00:00
|
|
|
.Sh EXIT STATUS
|
|
|
|
The
|
|
|
|
.Nm
|
|
|
|
utility prints an error message on the standard error output and exits with
|
|
|
|
status > 0 when it encounters an option letter not included in
|
|
|
|
.Ar optstring .
|
2000-11-17 11:44:16 +00:00
|
|
|
.Sh EXAMPLES
|
1993-07-26 22:22:37 +00:00
|
|
|
The following code fragment shows how one might process the arguments
|
|
|
|
for a command that can take the options
|
1996-10-22 21:56:11 +00:00
|
|
|
.Fl a
|
1993-07-26 22:22:37 +00:00
|
|
|
and
|
1996-10-22 21:56:11 +00:00
|
|
|
.Fl b ,
|
1993-07-26 22:22:37 +00:00
|
|
|
and the option
|
1996-10-22 21:56:11 +00:00
|
|
|
.Fl o ,
|
1993-07-26 22:22:37 +00:00
|
|
|
which requires an argument.
|
|
|
|
.Bd -literal -offset indent
|
1999-04-04 13:49:10 +00:00
|
|
|
args=\`getopt abo: $*\`
|
|
|
|
# you should not use \`getopt abo: "$@"\` since that would parse
|
|
|
|
# the arguments differently from what the set command below does.
|
2011-01-26 18:43:15 +00:00
|
|
|
if [ $? -ne 0 ]; then
|
1993-07-26 22:22:37 +00:00
|
|
|
echo 'Usage: ...'
|
|
|
|
exit 2
|
|
|
|
fi
|
1999-04-04 13:49:10 +00:00
|
|
|
set \-\- $args
|
|
|
|
# You cannot use the set command with a backquoted getopt directly,
|
2001-07-15 08:06:20 +00:00
|
|
|
# since the exit code from getopt would be shadowed by those of set,
|
1999-04-04 13:49:10 +00:00
|
|
|
# which is zero by definition.
|
2011-01-26 18:43:15 +00:00
|
|
|
while true; do
|
|
|
|
case "$1" in
|
|
|
|
\-a|\-b)
|
|
|
|
echo "flag $1 set"; sflags="${1#-}$sflags"
|
|
|
|
shift
|
|
|
|
;;
|
|
|
|
\-o)
|
|
|
|
echo "oarg is '$2'"; oarg="$2"
|
|
|
|
shift; shift
|
|
|
|
;;
|
|
|
|
\-\-)
|
|
|
|
shift; break
|
|
|
|
;;
|
1993-07-26 22:22:37 +00:00
|
|
|
esac
|
|
|
|
done
|
2011-01-26 18:43:15 +00:00
|
|
|
echo "single-char flags: '$sflags'"
|
|
|
|
echo "oarg is '$oarg'"
|
1993-07-26 22:22:37 +00:00
|
|
|
.Ed
|
|
|
|
.Pp
|
|
|
|
This code will accept any of the following as equivalent:
|
|
|
|
.Bd -literal -offset indent
|
|
|
|
cmd \-aoarg file file
|
|
|
|
cmd \-a \-o arg file file
|
|
|
|
cmd \-oarg -a file file
|
|
|
|
cmd \-a \-oarg \-\- file file
|
|
|
|
.Ed
|
|
|
|
.Sh SEE ALSO
|
2004-07-07 17:39:16 +00:00
|
|
|
.Xr getopts 1 ,
|
1993-07-26 22:22:37 +00:00
|
|
|
.Xr sh 1 ,
|
|
|
|
.Xr getopt 3
|
|
|
|
.Sh HISTORY
|
1999-09-05 05:50:38 +00:00
|
|
|
Written by
|
|
|
|
.An Henry Spencer ,
|
|
|
|
working from a Bell Labs manual page.
|
2000-03-01 12:20:22 +00:00
|
|
|
Behavior believed identical to the Bell version.
|
|
|
|
Example changed in
|
1999-04-03 22:24:36 +00:00
|
|
|
.Fx
|
|
|
|
version 3.2 and 4.0.
|
1993-07-26 22:22:37 +00:00
|
|
|
.Sh BUGS
|
|
|
|
Whatever
|
|
|
|
.Xr getopt 3
|
|
|
|
has.
|
|
|
|
.Pp
|
1999-04-04 00:25:39 +00:00
|
|
|
Arguments containing white space or embedded shell metacharacters
|
2004-07-03 00:24:45 +00:00
|
|
|
generally will not survive intact; this looks easy to fix but
|
2005-02-13 22:25:33 +00:00
|
|
|
is not.
|
2004-07-02 22:22:35 +00:00
|
|
|
People trying to fix
|
2000-11-20 19:21:22 +00:00
|
|
|
.Nm
|
1999-04-04 13:49:10 +00:00
|
|
|
or the example in this manpage should check the history of this file
|
|
|
|
in
|
|
|
|
.Fx .
|
1993-07-26 22:22:37 +00:00
|
|
|
.Pp
|
|
|
|
The error message for an invalid option is identified as coming
|
|
|
|
from
|
2000-11-20 19:21:22 +00:00
|
|
|
.Nm
|
1993-07-26 22:22:37 +00:00
|
|
|
rather than from the shell procedure containing the invocation
|
|
|
|
of
|
2000-11-20 19:21:22 +00:00
|
|
|
.Nm ;
|
1999-04-04 00:25:39 +00:00
|
|
|
this again is hard to fix.
|
|
|
|
.Pp
|
|
|
|
The precise best way to use the
|
|
|
|
.Nm set
|
|
|
|
command to set the arguments without disrupting the value(s) of
|
|
|
|
shell options varies from one shell version to another.
|
1999-04-04 13:49:10 +00:00
|
|
|
.Pp
|
|
|
|
Each shellscript has to carry complex code to parse arguments halfway
|
2004-07-02 22:22:35 +00:00
|
|
|
correctly (like the example presented here).
|
|
|
|
A better getopt-like tool
|
1999-04-04 13:49:10 +00:00
|
|
|
would move much of the complexity into the tool and keep the client
|
|
|
|
shell scripts simpler.
|