
while (("$#"))
do
opt="$1";
shift;
case "$opt" in
"-c" | "--create") create_flag=1 ;;
"-up" | "--update") update_flag=1 ;;
"-q" | "--query") query_flag=1 ;;
"-csr"| "--createabc") createsr_flag=1 ;;
"-g" | "--getconf") getconfig_flag=1 ;;
"-catt" | "--createandattach") createattach_flag=1 ;;
"-att" | "--attach") attach_flag=1 ;;
"--val1" ) callerId="$1" ;;
"--val2" ) title="$1" ;;
"--val3" ) urgency="$1" ;;
"--val4" ) environment="$1" ;;
"--val5" ) failType="$1" ;;
"--val6" ) jobName="$1" ;;
"--val7" ) jobType="$1" ;;
# usage();;
# "*" )
# OPTIONAL="${opt#*=}";; #take argument
# *) echo >&2 "Invalid option: $@"; exit 1;;
esac
shift
done
correndo
script.sh -c --val1 123456
não funciona !
script.sh --val1 123456 -c
Isso funciona !
Você pode explicar por quê?
Responder1
Você está chamando incondicionalmente shift
duas vezes por iteração. Isto é desejável para os --valN
casos, mas não para as opções que não aceitam um argumento seguinte. Você poderia pegar o caso geral e aninhá-lo para reduzir a duplicação:
case "$opt" in
"-c" | "--create") create_flag=1 ;;
"--val?" )
case "$opt" in
"--val1" ) callerId="$1" ;;
esac
shift
;;
esac
ou espalhe shift
em todas as opções que levam um argumento como:
case "$opt" in
"-c" | "--create") create_flag=1 ;;
"--val1" ) callerId="$1" ; shift ;;
esac
Você também pode encontrarobter opçõesútil para analisar opções no bash.
Responder2
Porque seu loop while muda incondicionalmente duas vezes, mesmo quando a opção não aceita argumento. A ordem da segunda linha de comando é apenas uma questão de sorte.