Eu gostaria de escrever alguns scripts que abririam vários painéis de terminal em uma única janela, como tmux
ou screen
.
Pessoalmente, sou bem versado em tmux
, e o uso há anos, mas outros desenvolvedores em nossa equipe não querem saber nada sobre ele ou outros multiplexadores de tela.
Para esse fim, gostaria de escrever scripts que possam se dividir em vários painéis em uma única janela. Isso é possível com bash direto?
Meus objetivos são
- evite exigir
node
ou algo que precise ser instalado, (como bendito-contrib ), para manter o processo o mais simples possível. - escreva-o usando algo pré-instalado na maioria das distros e compatível com posix.
- tem uma única janela de terminal que é dividida em painéis, onde cada painel pode ser um processo em execução ou um prompt de comando.
- quando alguém o atinge
ctrl+c
, sai de todos os painéis e retorna a um único terminal.
Eu acho que é seguro dizer que isso não pode ser feito apenas com o bash. Você precisará de uma linguagem de programação superior, como perl/python, ou controlar uma instância do tmux com um script.
Aqui está uma rápida revisão da tecnologia envolvida:
Existem algumas ferramentas que permitem que o bash chame ioctl , mas não acho que ele possa lidar com todas as chamadas necessárias para alocação de pty, e não é uma ferramenta padrão de qualquer maneira.
Você pode contornar isso criando manualmente nós de dispositivo pty, mas precisaria executar como root e seria uma bagunça.
bash pode descobrir várias sequências de escape de terminal a partir do
tput
comando, e você pode, de fato, escrever scripts bash que renderizam janelas de texto, mas sem ncurses isso é difícil de fazer corretamente e multiplataforma e levará muito do seu tempo.Em suma, eu não acho que você possa fazer isso com ferramentas simples de bash e posix.
Perl é instalado em quase todos os Unixes, e perl pode fazer
ioctl
chamadas, então sim, deve ser possível escrever isso em perl mesmo sem instalar nenhum módulo extra. No entanto, novamente, espero que demore muito sem usar pelo menos alguns módulos auxiliares extras como IO::Pty e Curses . Mas mesmo com tudo isso, há muito trabalho a fazer.Acho que sua melhor aposta é tentar scripts tmux . Eu não fiz isso antes, mas esse post dá a aparência de um projeto de alguns dias em vez de um projeto de algumas semanas e toneladas de aprendizado.
Se sua principal objeção é ter que instalar o tmux, você pode tentar baixar e compilar um binário estático do tmux e distribuí-lo com seu script. Um binário estático evita a dependência de qualquer biblioteca no sistema e deve funcionar em qualquer kernel Linux moderno da arquitetura correta. Você pode até compilar binários para várias arquiteturas e então fazer com que o script detecte qual binário usar.