Skip to content

Instantly share code, notes, and snippets.

Embed
What would you like to do?
Colorize Maven output
#!/bin/sh
# Written by Mike Ensor (mike@ensor.cc)
# Copywrite 2012
# Use as needed, modify, have fun!
# This is intended to be used for Maven3 + Mac OSX
#
# To use:
# in your ".bashrc" or ".bash_profile" add the following line:
# source ~/<path to script>/colorize-maven.sh
#
c_black=
c_cyan=
c_magenta=
c_red=
c_white=
c_green=
c_yellow=
c_blue=
c_bg_black=
c_bg_cyan=
c_bg_magenta=
c_bg_red=
c_bg_white=
c_bg_green=
c_bg_yellow=
c_bg_blue=
c_end=
c_bold=
xterm_color() {
# 0 Black
# 1 Red
# 2 Green
# 3 Yellow
# 4 Blue
# 5 Magenta
# 6 Cyan
# 7 White
# Yes, this could be a map
c_bold=`tput setaf 0`
c_bg_bold=`tput setab 0`
c_black=`tput setab 0`
c_bg_black=`tput setab 0`
c_cyan=`tput setaf 6`
c_bg_cyan=`tput setab 6`
c_magenta=`tput setaf 5`
c_bg_magenta=`tput setab 5`
c_red=`tput setaf 1`
c_bg_red=`tput setab 1`
c_white=`tput setaf 7`
c_bg_white=`tput setab 7`
c_green=`tput setaf 2`
c_bg_green=`tput setab 2`
c_yellow=`tput setaf 3`
c_bg_yellow=`tput setab 3`
c_blue=`tput setaf 4`
c_bg_blue=`tput setab 4`
c_end=`tput sgr0`
}
ansi_color() {
c_bold= '[1m'
c_blue= '[1;34m'
c_black= '[1;30m'
c_green= '[1;32m'
c_magenta='[1;35m'
c_red= '[1;31m'
c_cyan= '[1;36m'
c_end= '[0m'
}
color_maven() {
# pick color type
if [ $TERM = 'xterm-color' ]
then
xterm_color
# elif [ $TERM = 'ansi' ]
# then
# ansi_color
else
echo "${c_red}WARNING:::Terminal '${TERM}' is not supported at this time. Colorized output will not happen for Maven${c_end}"
fi
error=${c_bold}${c_red}
info=${c_white}
warn=${c_yellow}
success=${c_green}
projectname=${c_bold}${c_cyan}
skipped=${c_white}
downloading=${c_magenta}
$MAVEN_HOME/bin/mvn $* | sed -e "s/(\[INFO\]) Building( .*)/${info}\1${projectname}\2${c_end}/g" \
-e "s/(Time elapsed: )([0-9]+[.]*[0-9]*.sec)/${c_cyan}\1${c_white}\2${c_end}/g" \
-e "s/(Downloading: .*)/${downloading}\1${c_end}/g" \
-e "s/BUILD FAILURE/${error}BUILD FAILURE${c_end}/g" \
-e "s/WARNING: ([a-zA-Z0-9.-/\\ :]+)/${warn}WARNING: \1${c_end}/g" \
-e "s/SEVERE: (.+)/${c_white}${c_bg_red}SEVERE: \1${c_end}/g" \
-e "s/Caused by: (.+)/${c_white}${c_bg_green}Caused by: \1${c_end}/g" \
-e "s/Running (.+)/${c_green}Running \1${c_end}/g" \
-e "s/FAILURE (\[[0-9]+.[:0-9]+s\])/${error}FAILURE \1${c_end}/g" \
-e "s/SUCCESS (\[[0-9]+.[:0-9]+s\])/${success}SUCCESS \1${c_end}/g" \
-e "s/(\[INFO.*)/${info}\1${c_end}/g" \
-e "s/INFO: (.+)/${c_white}INFO: \1${c_end}/g" \
-e "s/(\[WARN.*)/${warn}\1${c_end}/g" \
-e "s/(\[ERROR.*)/${error}\1${c_end}/g" \
-e "s/(<<< FAILURE!)/${error}\1${c_end}/g" \
-e "s/Tests run: ([0-9]*), Failures: ([0-9]*), Errors: ([0-9]*), Skipped: ([0-9]*)/${c_green}Tests run: \1 ${c_end}, Failures: ${warn}\2 ${c_end}, Errors: ${error}\3 ${c_end}, Skipped: ${skipped}\4 ${c_end}/g"
}
alias mvn=color_maven
@The-Alchemist

This comment has been minimized.

Copy link

The-Alchemist commented Oct 24, 2012

Unfortunately, this doesn't work on Cygwin :(

$ color_maven
WARNING:::Terminal 'xterm' is not supported at this time. Colorized output will not happen for Maven
-bash: /bin/mvn: No such file or directory
sed: -e expression #1, char 35: invalid reference \2 on `s' command's RHS
@hale

This comment has been minimized.

Copy link

hale commented Feb 26, 2013

I can't even get the script to parse.

bash

bash: colorize-maven.sh: line 88: syntax error near unexpected token `Time'
bash: colorize-maven.sh: line 88: `        -e "s/(Time elapsed: )([0-9]+[.]*[0-9]*.sec)/${c_cyan}\1${c_white}\2${c_end}/g" \'

zsh

colorize-maven.sh:101: parse error near `)'
@marc-guenther

This comment has been minimized.

Copy link

marc-guenther commented Sep 24, 2013

I had to use the -E option to sed. Also to allow spaces in arguments, I use "$@" instead of $*

"$MAVEN_HOME/bin/mvn" "$@" | sed -E -e ....

(I'm on MacOSX 10.8.4 and using zsh)

@daniilyar

This comment has been minimized.

Copy link

daniilyar commented Sep 29, 2013

-bash: /bin/mvn: No such file or directory

check your MAVEN_HOME and M2_HOME env vars.
If you have only M2_HOME env var set, just use it in script instead MAVEN_HOME

sed: -e expression #1, char 35: invalid reference \2 on `s' command's RHS

I have the same on Ubuntu 12.10

@srikanth-katare

This comment has been minimized.

Copy link

srikanth-katare commented Apr 22, 2016

Hi I'm new to Git, how to use this colorize-maven.sh in Windows OS while running maven install
I had set MAVEN_HOME and GIT\bin set to PATH already,

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
You can’t perform that action at this time.