Velvet Star Monitor

Standout celebrity highlights with iconic style.

updates

How to use a space in date format section of annotate-output?

Writer Olivia Zamora

I try to use annotate-output (part of devscripts package), to prefix outputs of a script with date and some extra info. First parameter can be a format string passed to date. I want to include a space in this format string, however, being a bash newbie I have no idea, how to escape the space to get it sent to date properly. Tried a bunch of options, but looks like no matter what I provide, sys just eats it...

Source of annotate-output can be found HERE.

user@host:/home/user$ annotate-output '+myscript: %H:%M:%S' echo "A"
date: extra operand `%H:%M:%S'
Try `date --help' for more information. I: Started echo A
date: extra operand `%H:%M:%S'
Try `date --help' for more information. O: A
date: extra operand `%H:%M:%S'
Try `date --help' for more information. I: Finished with exitcode 0

Expected output:

myscript: 14:04:16 I: Started echo A
myscript: 14:04:16 O: A
myscript: 14:04:16 I: Finished with exitcode 0

2 Answers

Unfortunately that script has some quoting issues. It will work if you add this function to the code:

date ()
{ command date "$*"
}

Actually you don't need to alter the source. Do this: define the "date" function and export it:

$ date() { command date "$*"; }
$ export -f date
$ annotate-output "+foo %T" bash -c "echo stdout; echo stderr >&2"
foo 10:38:30 I: Started bash -c echo stdout; echo stderr >&2
foo 10:38:30 E: stderr
foo 10:38:30 O: stdout
foo 10:38:30 I: Finished with exitcode 0

There might be problems if the thing you're annotating also calls date.


If you care to fix annotate-output on your system, apply this diff

$ diff /usr/bin/annotate-output bin/annotate-output
28c28
< echo "`date ${FMT}` $1: $line"
---
> printf "%s %s: %s\n" "$(date "$FMT")" "$1" "$line"
78c78
< echo "`date ${FMT}` I: Started $@"
---
> addtime I <<< "Started $*"
83c83
< echo "`date ${FMT}` I: Finished with exitcode $EXIT"
---
> addtime I <<< "Finished with exitcode $EXIT"
3

It will work if you quote parameter properly:

annotate-output '+"myscript: %H:%M:%S"' echo "A"

date command's format argument starts with +. That's right. But in order to pass space into it you should wrap all chars after + with quotes. Otherwise it will accept symbols which are following the whitespace as second command line argument.

1

Your Answer

Sign up or log in

Sign up using Google Sign up using Facebook Sign up using Email and Password

Post as a guest

By clicking “Post Your Answer”, you agree to our terms of service, privacy policy and cookie policy