別のコマンドを実行してスクリプトの後続のステップを続行する前に、戻りコードを確認したいと思います。同時に、teeコマンドを使用して実行されたコマンドの出力をファイルに記録したいと思います。例:
#set non-existing folder
local_path="~/njn"
log_path_file="test.log"
cmd="ls -l ${local_path} | tee -a ${log_path_file}";
eval ${cmd}
returncode=$?
echo "execution result: ${returncode}" | tee -a ${log_path_file};
if [ ${returncode} -eq 0 ]; then
echo "success" | tee -a ${log_path_file}
else
echo "not success" | tee -a ${log_path_file}
fi
戻りコードは0です。 0より大きくなければなりません。
returncode変数が実行されたコマンド(この場合はls -lコマンド)の実際の戻り値を持つことを望みます。
ファイルを使用してコマンド出力を作成し、ファイルから戻りコードを読み取るソリューションがあります(ここ)、しかし私はもう少しエレガントな解決策を探しています。
ベストアンサー1
ls -l
この特別なケースでは、終了ステータスを実行してアクションを実行する方が簡単です。
if ls -l "$local_path"; then
echo 'success'
else
printf 'failure (code %d)\n' "$?"
fi | tee -a "$log_path_file"
bash
シェルでは、配列の値を参照することもできますPIPESTATUS
。
$ false | true | true | false | false
$ printf '%s\n' "${PIPESTATUS[@]}"
1
0
0
1
1
あなたの場合:
ls -l "$local_path" | tee -a "$log_path_file"
ls_status=${PIPESTATUS[0]}
if [ "$ls_status" -eq 0 ]; then
echo 'success'
else
printf 'failure (code %d)\n' "$ls_status"
fi | tee -a "$log_path_file"