sendack.sh

来自「开放源码实时操作系统源码.」· Shell 代码 · 共 43 行

SH
43
字号
#!/bin/sh

if [ $# -gt 2 ] || [ $# -lt 1 ]; then
    echo "Usage: $0 [XFAIL] target-IP [port]" > /dev/stderr
    exit 1
fi

[ "xXFAIL" == "x$1" ] && { XFAIL="XFAIL"; shift; }

TARGET=$1; shift

PORT=9990; [ "x" != "x$1" ] && { PORT=$1; shift; }

while [ true ]; do

    read -a RESULT || {	exit 0; }

    echo "$TARGET: result ${RESULT[@]}"

    # I really want it to try quite hard to get the message through
    # (but not too hard if XFAIL)
    echo "${RESULT[@]} ($TARGET)" > /dev/tcp/$TARGET/$PORT || \
    echo "${RESULT[@]} ($TARGET)" > /dev/tcp/$TARGET/$PORT || \
    { sleep 1 && { \
    echo "${RESULT[@]} ($TARGET)" > /dev/tcp/$TARGET/$PORT || \
    echo "${RESULT[@]} ($TARGET)" > /dev/tcp/$TARGET/$PORT || \
    { sleep 3 && { \
    echo "${RESULT[@]} ($TARGET)" > /dev/tcp/$TARGET/$PORT || \
    echo "${RESULT[@]} ($TARGET)" > /dev/tcp/$TARGET/$PORT || \
    { [ "x$XFAIL" != "xXFAIL" ] && sleep 5 && { \
    echo "${RESULT[@]} ($TARGET)" > /dev/tcp/$TARGET/$PORT || \
    echo "${RESULT[@]} ($TARGET)" > /dev/tcp/$TARGET/$PORT || \
    { sleep 10 && { \
    echo "${RESULT[@]} ($TARGET)" > /dev/tcp/$TARGET/$PORT || \
    echo "${RESULT[@]} ($TARGET)" > /dev/tcp/$TARGET/$PORT || \
    echo "***FAILED TO SEND RESULT TO $TARGET: result ${RESULT[@]}" \
    ;};};};};};};};}
    # brute force seems as good as any means...

done

# EOF

⌨️ 快捷键说明

复制代码Ctrl + C
搜索代码Ctrl + F
全屏模式F11
增大字号Ctrl + =
减小字号Ctrl + -
显示快捷键?