답변:
shift $((OPTIND-1))
(참고 OPTIND
는 대문자입니다)는 일반적으로 getopts
while
루프 직후에 발견 됩니다. $OPTIND
에서 찾은 옵션 수입니다 getopts
.
pauljohn32가 주석에서 언급했듯이 엄밀히 말하면 다음 명령 줄 인수 OPTIND
의 위치를 제공합니다 .
GNU Bash 참조 매뉴얼에서 :
getopts optstring 이름 [args]
getopts
쉘 스크립트에서 위치 매개 변수를 구문 분석하는 데 사용됩니다.optstring
인식 할 옵션 문자를 포함합니다. 문자 뒤에 콜론이 오는 경우 옵션에는 인수가 있어야하며 공백으로 구분해야합니다. 콜론 ( ':')과 물음표 ( '?')는 옵션 문자로 사용할 수 없습니다. 호출 될 때마다getopts
다음 옵션을 쉘 변수 이름에 배치하고name
존재하지 않는 경우 초기화 하고 변수로 처리 할 다음 인수의 색인을 배치합니다OPTIND
.OPTIND
쉘 또는 쉘 스크립트가 호출 될 때마다 1로 초기화됩니다. 옵션에 인수가 필요한 경우, getopts는 해당 인수를 변수에 배치합니다OPTARG
. 쉘이 재설정되지 않습니다OPTIND
자동;getopts
새로운 매개 변수 세트를 사용하려면 동일한 호출에서 여러 호출 사이에서 수동으로 재설정해야합니다 .옵션 끝이 발견되면
getopts
리턴 값이 0보다 큰 상태로 종료합니다.OPTIND
는 옵션이 아닌 첫 번째 인수의 색인으로 설정되고 이름은 '?'로 설정됩니다.
getopts
일반적으로 위치 매개 변수를 구문 분석하지만에 더 많은 인수가 제공args
되면getopts
대신 구문 분석합니다.
shift
n
은 위치 매개 변수 목록에서 n 개의 문자열을 제거 합니다. 따라서 매개 변수 목록에서 shift $((OPTIND-1))
구문 분석 된 모든 옵션을 제거 getopts
하므로 해당 시점 이후 $1
에 스크립트에 전달 된 첫 번째 비 옵션 인수를 참조합니다.
최신 정보
코멘트에서 mikeserv가 언급했듯이 shift $((OPTIND-1))
안전하지 않을 수 있습니다. 원치 않는 단어 분리 등을 방지하려면 모든 매개 변수 확장을 큰 따옴표로 묶어야합니다. 명령의 안전한 형태는
shift "$((OPTIND-1))"
find
) 수도 보면 그들이 비 선택 후 옵션을 허용처럼,하지만 그들은하지 : 그들은 대시로 시작 피연산자가 있습니다.
IFS
일이지만 미안보다 안전합니다. ;)
IFS=0123456789
, shift $((OPTIND-1))
(따옴표없이)는로 바뀝니다 shift ""
되는이 자동으로 (무시한다 ksh
) 또는 (에서 오류를 생성 bash
하고 dash
).