残念ながら、ドイツのガルシアは正しいので、回避策を書きました。
どんな提案や改善も歓迎の感謝以上のものです。
これが私がこれまでにしたことです:
#!/bin/bash
set -o pipefail
set -o errtrace
set -o nounset
set -o errexit
declare stderr_log="/dev/shm/stderr.log"
exec 2>"${stderr_log}"
function err_handler ()
{
local error_code=${1:-$?}
echo "TRAP! ${error_code}"
echo "exit status: $error_code"
stderr=$( tail -n 1 "$stderr_log" )
echo "error message: $stderr"
echo "" > "${stderr_log}"
echo "Normally I would exit now but I carry on the demo instead"
# uncomemment the following two lines to exit now.
# rm "${stderr_log}"
# exit "${error_code}"
}
trap err_handler ERR
function check ()
{
local params=( "$@" )
local result=0
local statement=''
for param in "${params[@]}"
do
local regex='\s+'
if [[ ${param} =~ ${regex} ]]
then
param=$( echo "${param}" | sed 's/"/\\"/g' )
param="\"$param\""
fi
statement="${statement} $param"
done
eval "if $statement; then result=1; fi"
stderr=$( tail -n 1 "$stderr_log" )
($statement); local error_code="$?"
test -n "$stderr" && err_handler "${error_code}"
test $result = 1 && [[ $( echo "1" ) ]] || [[ $( echo "" ) ]]
}
echo -e "\n1) wrong command in if statement"
if check xsxsxs -d "/etc"
then
echo "if returns true"
else
echo "if returns false"
fi
echo -e "\n2) right command in if statement"
if check test -d "/etc"
then
echo "if returns true"
else
echo "if returns false"
fi
echo -e "\n3) wrong command directly"
xsxsxsxs
exit
上記を実行すると、次のようになります。
1) wrong command in if statement
TRAP!
error code found: 0
error message: trap.sh: line 52: xsxsxs: command not found
I would exit now but I carry on instead
if returns false
2) right command in if statement
if returns true
3) wrong command directly
TRAP!
error code found: 127
error message: trap.sh: line 77: xsxsxsxs: command not found
I would exit now but I carry on instead
したがって、基本的には、「check」というメソッドを作成し、それをコマンドの前に追加して、ifステートメントでデバッグするという考え方です。
この方法でエラーコードをキャッチすることはできませんが、メッセージを受信できる限り、それほど重要ではありません。
それについてあなたから聞いていただければ幸いです。ありがとう