关闭背景Zenity对话框时,终止脚本



我在这里编写了一个相当简单的脚本,该脚本旨在使用zenity显示文本信息对话框,并连续读取远程TCP连接的数据并将其显示在对话框中。这有效...但是,如果我关闭zenity对话框,我希望整个脚本终止。

有办法做到这一点吗?我认为我无法在循环中检查任何内容,因为脚本可能会停滞在远程TCP连接中的数据上。

#!/bin/bash
on_exit() {
        zenity --display=:0 --error --text="Script has exited." &
}
# Options
while getopts "a:p:t:" OPTION; do case "$OPTION" in
        a) address="$OPTARG";;
        p) port="$OPTARG";;
        t) title="$OPTARG";;
esac; done
exec &> >(zenity --display=:0 --text-info --title=$title || exit)
                               # doesn't make a difference?  ↑
                               # also tried &&
trap "on_exit" EXIT
while read data < /dev/tcp/$address/$port; do
        echo $data
        # ...
        # do some other stuff with the information
        # ...
done

注意:这将在Igel Linux上运行。我没有安装其他软件包的选择。因此,理想情况下,我要寻找的解决方案是本地狂欢的原生。


更新

我只需要进行此修改即可继续使用exec。或 @bachlien使用命名管的答案也有效。

PID=$$
exec &> >(zenity --display=:0 --text-info --title=$title; kill $PID)

我没有安装zenity,所以我尝试了此脚本来说明这个想法。

程序 terminal+cat(emmulating zenity(由在后台运行的函数_dspMsg执行(子进程(;cat连续显示来自文件($m(的消息,该消息是命名管道;当terminal+cat退出时,父进程是kill ED。

同时,另一个 cat proccess将杂物写入管道$m(删除TPC信息馈送(;当_dspMsg退出时,它将被杀死。

#!/bin/bash
                              # 1) named pipe
m=`mktemp -u /tmp/msg-XXXX=`  #    get a temporary filename (for named pipe)
mkfifo "$m"                   #    create that named pipe
trap "echo END; rm $m" EXIT   #    remove that file when exit
                              # 2) zenity
_dspMsg(){                    #    continuously display messages
  urxvt -e bash -c "cat <$m"  #    terminal+cat is used in place of zenity
  kill $1                     #    kill parent pid
}                             #    to be run in background
_dspMsg $$ &                  #    $$ = proccess id
                              # 3) TCP info feeds
cat >>"$m"                    #    feeding messages using cat
                              #    cat is used in placed of TCP data feed

注意:

  1. 命名管被用作父母和子过程之间交流的一种方式。
  2. 要测试该脚本,您可能需要将urxvt更改为xtermiTerm或计算机中可用的任何其他终端弹出器。

所以,也许这是您需要的(未经测试(:

#!/bin/bash
while getopts "a:p:t:" OPTION; do case "$OPTION" in
  a) address="$OPTARG";;
  p) port="$OPTARG";;
  t) title="$OPTARG";;
esac; done
m=`mktemp -u /tmp/msg-XXXX=`
mkfifo "$m"
trap "zenity --display=:0 --error --text='Script has exited.' & rm $m" EXIT
_dspMsg(){
  zenity --display=:0 --text-info --title="$title" <"$m"
  kill $1
}
_dspMsg $$ &
while read data < /dev/tcp/$address/$port; do
  echo $data >>"$m"
done

您可以将while环路的所有输出输送到Zenity中,从而摆脱exec &>的需求。

while read data < "/dev/tcp/$address/$port"; do
        echo "$data"
done | zenity --display=:0 --text-info --title="$title"

相关内容

  • 没有找到相关文章

最新更新