e6c683289722fd5cea4e46e00dedfb70b3e749e1
2 # Copyright (C) 2014-2016 Ian Kelling
4 # Licensed under the Apache License, Version 2.0 (the "License");
5 # you may not use this file except in compliance with the License.
6 # You may obtain a copy of the License at
8 # http://www.apache.org/licenses/LICENSE-2.0
10 # Unless required by applicable law or agreed to in writing, software
11 # distributed under the License is distributed on an "AS IS" BASIS,
12 # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13 # See the License for the specific language governing permissions and
14 # limitations under the License.
16 local help="Usage: logq [-h|--help] COMMAND [ARG...]
18 Log to temp file, output tail of log in case of error.
20 Run COMMAND with ARGs. Output return code, command, and log path. Tail
21 log if there is a failure. Follows output format of logsave."
23 if [[ $1 == --help ||
$1 == -h ]]; then
27 if [[ $# == 0 ]]; then
28 echo "error: need 1 or more arguments
33 # deliniate arguments, so spaces aren't ambiguous
37 prettycommand
+="[$index]$x "
42 file="$(mktemp -d)/${file//[[:space:]\/]/_}"
43 # give us ~20 char filename max
46 printf "%s\n%s\n\n" "Log of $prettycommand" "$(date)" >"$file"
48 if [[ $
- != *x
* ]]; then
52 # we will propagate any errors
59 printf "\n%s\n%s\n" "$(date)" "----------------" >> "$file"
61 if [[ $logq_ret != 0 ]]; then
63 if [[ $
- != *x
* ]]; then
64 echo "logq failure. $x :"