我在这里编写了一个相当简单的脚本,该脚本旨在使用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
注意:
- 命名管被用作父母和子过程之间交流的一种方式。
- 要测试该脚本,您可能需要将
urxvt
更改为xterm
,iTerm
或计算机中可用的任何其他终端弹出器。
所以,也许这是您需要的(未经测试(:
#!/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"