Shell com ordem de entrada de parâmetros é o problema

Shell com ordem de entrada de parâmetros é o problema
     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 shiftduas vezes por iteração. Isto é desejável para os --valNcasos, 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 shiftem 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.

informação relacionada