Shell snippet that prepends a nice to a command's output.
For example, here's the (snipped) output of vagrant provision:
Successfully installed bundler-1.3.5  
1 gem installed  
Using rmagick (2.13.2)  
Using bundler (1.3.5)  
Use `bundle show [gemname]` to see where a bundled gem is installed.  
[default] Running provisioner: shell...  
[default] Running: inline script  
Would you prefer to see the following?
18:32:05.055   Successfully installed bundler-1.3.5  
18:32:05.055   1 gem installed  
18:32:05.282   Using rmagick (2.13.2)  
18:32:05.282   Using bundler (1.3.5)  
18:32:05.285   Use `bundle show [gemname]` to see where a bundled gem is installed.  
18:32:05.291   [default] Running provisioner: shell...  
18:32:05.789   [default] Running: inline script  
Then simply append this snippet to your command, as follows:
vagrant provision 2>&1 | ruby -ne 'puts "\e[33m" + Time.now().strftime("%T.%L") + "\e[0m " + $_'Keep in mind the following:
- 2>&1redirects stderr to stdout (pipes only work on stdout)
- \e[33mand- \e[0mare terminal escape codes that make the text between them yellow
- %Tis HH:MM:SS and- %Ladds milliseconds in the time formatting command.
Prefer to invoke the script in a friendlier way?
vagrant up 2>&1 | prepend-timestampThen do the following:
## 
## Creates a ~/bin folder and ensure it's in $PATH; 
## via http://askubuntu.com/a/247422/194314
##
mkdir ~/bin
cat - >> ~/.bashrc <<'EOT'
# set PATH so it includes user's private bin if it exists
if [ -d "$HOME/bin" ] ; then
    PATH="$HOME/bin:$PATH"
fi
EOT
source ~/.bashrc
##
## Installs ~/bin/prepend-timestamp and makes it executable
##
cat - > ~/bin/prepend-timestamp <<'EOT'
#!/bin/sh
ruby -ne 'puts "\e[33m" + Time.now().strftime("%T.%L") + "\e[0m " + $_'
EOT
chmod u+x ~/bin/prepend-timestampDone!