AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • Início
  • system&network
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • Início
  • system&network
    • Recentes
    • Highest score
    • tags
  • Ubuntu
    • Recentes
    • Highest score
    • tags
  • Unix
    • Recentes
    • tags
  • DBA
    • Recentes
    • tags
  • Computer
    • Recentes
    • tags
  • Coding
    • Recentes
    • tags
Início / ubuntu / Perguntas / 1147775
Accepted
WinEunuuchs2Unix
WinEunuuchs2Unix
Asked: 2019-06-01 17:43:37 +0800 CST2019-06-01 17:43:37 +0800 CST 2019-06-01 17:43:37 +0800 CST

O que o shellcheck aviso SC2129 “Considere usar { cmd1; cmd2; } >> arquivo em vez de redirecionamentos individuais.” significa?

  • 772

Eu tenho este shellcheckaviso que não consigo descobrir:

In /mnt/e/bin/iconic line 540:
            printf "FALSE|" >> "$IconsRaw"           # Select field number 1
            ^-- SC2129: Consider using { cmd1; cmd2; } >> file instead of individual redirects.

Percebi que muitos de nós aqui usamos shellcheck para corrigir nossos scripts bash / comandos shell, então espero que a pergunta esteja no tópico.


De acordo com os comentários postando a seção relevante do script bash:

    if [[ "$X" == "?" || "$Y" == "?" ]] ; then
        : # Bad X or Y offset usually "Link to Name.ext~" (backup name)
    else
        let i++
        printf "FALSE|" >> "$IconsRaw"           # Select field number 1
        printf "%s|" "$i" >> "$IconsRaw"         # 2
        printf "%s|" "${File##*/}" >> "$IconsRaw"
        printf "%s|" "$Linkless" >> "$IconsRaw"  # 4
        printf "%s|" "$Date" >> "$IconsRaw"      # 5
        printf "%s|" "$X" >> "$IconsRaw"         # 6
        echo   "$Y" >> "$IconsRaw"               # 7
    fi

Solução

Graças a respostas e comentários aceitos, aprendi que shellchecknão apenas detecta erros em seu código, mas também sugere melhorias de desempenho. Nesse caso, o nome do arquivo $IconsRawestava sendo aberto e fechado várias vezes com cada printfe echo.

O código bash mais eficiente:

    # X,Y screen coordinates invalid on backup files ending with "~"
    ! [[ "$X" == "?" || "$Y" == "?" ]] && { let i++; echo \
        "FALSE|$i|${File##*/}|$Linkless|$Date|$X|$Y" >> "$IconsRaw"; }
bash debugging output
  • 1 1 respostas
  • 861 Views

1 respostas

  • Voted
  1. Best Answer
    terdon
    2019-06-01T17:47:20+08:002019-06-01T17:47:20+08:00

    Presumo que seu script tenha várias instâncias de >> "$IconsRaw". Essa mensagem sugere redirecionar a saída apenas uma vez e agrupar os comandos em um subshell. Presumivelmente para evitar a sobrecarga de abrir e fechar o arquivo várias vezes.

    Então, em vez disso:

        printf "FALSE|" >> "$IconsRaw"           # Select field number 1
        printf "%s|" "$i" >> "$IconsRaw"         # 2
        printf "%s|" "${File##*/}" >> "$IconsRaw"
        printf "%s|" "$Linkless" >> "$IconsRaw"  # 4
        printf "%s|" "$Date" >> "$IconsRaw"      # 5
        printf "%s|" "$X" >> "$IconsRaw"         # 6
        echo   "$Y" >> "$IconsRaw"               # 7
    

    Este:

    {
        printf "FALSE|"            # Select field number 1
        printf "%s|" "$i"          # 2
        printf "%s|" "${File##*/}" 
        printf "%s|" "$Linkless"   # 4
        printf "%s|" "$Date"       # 5
        printf "%s|" "$X"          # 6
        printf "%s\n" "$Y"         # 7
    } >> "$IconsRaw"
    

    Mas isso também é uma repetição desnecessária printfe é mais eficiente apenas fazer:

    printf '%s|%s|%s|%s|%s|%s|%s\n' \
          'FALSE' "$i" "${File##*/}" "$Linkless" \
          "$Date" "$X" "$Y" >> "$IconsRaw"
    
    • 8

relate perguntas

Sidebar

Stats

  • Perguntas 205573
  • respostas 270741
  • best respostas 135370
  • utilizador 68524
  • Highest score
  • respostas
  • Marko Smith

    Existe um comando para listar todos os usuários? Também para adicionar, excluir, modificar usuários, no terminal?

    • 9 respostas
  • Marko Smith

    Como excluir um diretório não vazio no Terminal?

    • 4 respostas
  • Marko Smith

    Como descompactar um arquivo zip do Terminal?

    • 9 respostas
  • Marko Smith

    Como instalo um arquivo .deb por meio da linha de comando?

    • 11 respostas
  • Marko Smith

    Como instalo um arquivo .tar.gz (ou .tar.bz2)?

    • 14 respostas
  • Marko Smith

    Como listar todos os pacotes instalados

    • 24 respostas
  • Martin Hope
    Flimm Como posso usar o docker sem sudo? 2014-06-07 00:17:43 +0800 CST
  • Martin Hope
    led-Zepp Como faço para salvar a saída do terminal em um arquivo? 2014-02-15 11:49:07 +0800 CST
  • Martin Hope
    ubuntu-nerd Como descompactar um arquivo zip do Terminal? 2011-12-11 20:37:54 +0800 CST
  • Martin Hope
    TheXed Como instalo um arquivo .deb por meio da linha de comando? 2011-05-07 09:40:28 +0800 CST
  • Martin Hope
    Ivan Como listar todos os pacotes instalados 2010-12-17 18:08:49 +0800 CST
  • Martin Hope
    David Barry Como determino o tamanho total de um diretório (pasta) na linha de comando? 2010-08-06 10:20:23 +0800 CST
  • Martin Hope
    jfoucher "Os seguintes pacotes foram retidos:" Por que e como resolvo isso? 2010-08-01 13:59:22 +0800 CST
  • Martin Hope
    David Ashford Como os PPAs podem ser removidos? 2010-07-30 01:09:42 +0800 CST

Hot tag

10.10 10.04 gnome networking server command-line package-management software-recommendation sound xorg

Explore

  • Início
  • Perguntas
    • Recentes
    • Highest score
  • tag
  • help

Footer

AskOverflow.Dev

About Us

  • About Us
  • Contact Us

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve