On Thu, Oct 14, 2010 at 12:02:45PM -0430, Carlos Diaz wrote: > In some systems, such as Freebsd, the base tput isn't linked against a > terminfo capable ncurses. > > This means that there's no portable way to set color, so instead of > guessing, makepkg fallbacks on using legacy termcap output manipulation. > > For reference, see terminfo(5) and termcap(5) for a comparison between > the abilities. > > The hardcoded list of terminals is taken from freebsdports/shells/tcshrc > and tmux [1]. This prevents echoing gibberish in dumb and otherwise > incapacitated terminals. > > 1: > http://www.openbsd.org/cgi-bin/cvsweb/src/usr.bin/tmux/tty.c?rev=1.91;content-type=text%2Fplain > > Signed-off-by: Carlos Diaz <839...@gmail.com> > --- > scripts/makepkg.sh.in | 13 +++++++++++-- > 1 files changed, 11 insertions(+), 2 deletions(-) > > diff --git a/scripts/makepkg.sh.in b/scripts/makepkg.sh.in > index bdf63ef..3d29d26 100644 > --- a/scripts/makepkg.sh.in > +++ b/scripts/makepkg.sh.in > @@ -1660,21 +1660,30 @@ PACMAN=${PACMAN:-pacman} > # check if messages are to be printed using color > unset ALL_OFF BOLD BLUE GREEN RED YELLOW > if [[ -t 2 && ! $USE_COLOR = "n" && $(check_buildenv color) = "y" ]]; then > - # prefer terminal safe colored and bold text when tput is supported > if tput setaf 0 &>/dev/null; then > + # tput linked against a compliant terminfo ncurses > ALL_OFF="$(tput sgr0)" > BOLD="$(tput bold)" > BLUE="${BOLD}$(tput setaf 4)" > GREEN="${BOLD}$(tput setaf 2)" > RED="${BOLD}$(tput setaf 1)" > YELLOW="${BOLD}$(tput setaf 3)" > - else > + elif [[ $TERM =~ ^(dtterm|rxvt|screen|xterm) ]]; then > + # no terminfo, but don't fallback to ugly reverse text just yet > ALL_OFF="\033[1;0m" > BOLD="\033[1;1m" > BLUE="${BOLD}\033[1;34m" > GREEN="${BOLD}\033[1;32m" > RED="${BOLD}\033[1;31m" > YELLOW="${BOLD}\033[1;33m" > + elif tput me &>/dev/null; then > + # rely on termcap capabilities; no portable way of using color > + ALL_OFF="$(tput me)" > + BOLD="$(tput md)" > + BLUE="$(tput mr)" # reverse > + GREEN="$(tput us)" # underline > + RED="$(tput so)" # standout > + YELLOW="$(tput mh)" # half-bright > fi > fi > readonly ALL_OFF BOLD BLUE GREEN RED YELLOW > -- > 1.7.3.1 > >
This is already fixed in master!