НАЗВАНИЕ
getopts - разбор опций команды
СИНТАКСИС
getopts цепочка_опций имя [аргумент ...]
ОПИСАНИЕ
Команда getopts используется shell-процедурами для разбора позиционных параметров и проверки опций на допустимость. Команда getopts поддерживает все применимые
правила стандартного синтаксиса команд [см. intro(1), правила 3-10].
Цепочка_опций должна содержать флаги, которые будут распознаваться shell-процедурой, использующей getopts. Если за флагом следует двоеточие, то предполагается, что опция имеет аргумент или группу аргументов, которые должны отделяться от флага пробелами или табуляциями.
После каждого вызова getopts помещает следующую опцию в переменную имя, а номер аргумента, который должен быть обработан следующим, - в переменную OPTIND. Всегда, когда запускается shell или shell-процедура, OPTIND получает значение 1.
Если опции требуется аргумент, то getopts помещает его в переменную OPTARG.
Если встретилась некорректная опция, то в переменную имя помещается ?.
Если опции кончились, getopts возвращает ненулевой код завершения. Можно использовать специальную опцию --, чтобы отметить конец опций.
По умолчанию команда getopts разбирает позиционные параметры вызвавшей ее shell-процедуры, но если указать дополнительные аргументы, то getopts будет разбирать их.
ПРИМЕР
Следующий фрагмент shell-процедуры cmd показывает, как
можно обработать аргументы команды, допускающей опции a
и b, а также опцию o, которая должна иметь аргумент:
while getopts abo: c do case $c in a | b) FLAG=$c;; o) OARG=$OPTARG;; ?) echo $USAGE exit 2;; esac done shift `expr $OPTIND - 1`При такой обработке следующие строки оказываются эквивалентными:
cmd -a -b -o "xxx z yy" file cmd -a -b -o "xxx z yy" -- file cmd -ab -o xxx,z,yy file cmd -ab -o "xxx z yy" file cmd -o xxx,z,yy -b -a file
ПРИМЕЧАНИЯ
Утверждение о эквивалентности предыдущих строк не вполне верно:
ФАЙЛЫ
/usr/bin/getopt Старая версия программы разбора опций. /usr/lib/getoptcvt Программа перевода shell-проце- дур, использовавших getopt, на getopts.
СМ. ТАКЖЕ
gutil(1G), intro(1), sh(1).
getopt(3C) в Справочнике программиста.
ДИАГНОСТИКА
Команда getopts выводит сообщение об ошибке в стандартный протокол, когда встречается опция, не включенная в цепочку_опций.
ПРЕДОСТЕРЕЖЕНИЯ
Хотя текущая реализация getopts допускает некоторые
отступления от правил, задающих синтаксис команд [см.
intro(1)], этим не следует пользоваться, так как подобные возможности могут не поддерживаться в следующих версиях системы. Пусть, как и в ПРИМЕРЕ, a и b - опции
без аргументов, а опции o требуется аргумент:
cmd -aboxxx fileЗдесь нарушено правило 5: опция с аргументом не должна быть в одной группе с остальными опциями.
cmd -ab -oxxx fileНарушено правило 6: после опции, которой требуется аргумент, должен быть пробел или табуляция.
Изменение значения переменной OPTIND или разбор различных наборов аргументов могут привести к непредсказуемому результату.