* @license http://www.opensource.org/licenses/mit-license.php MIT License * @link http://pear.php.net/package/Console_Color2 */ /** * A simple class to use ANSI Colorcodes. * * Of all the functions, you probably only want to use convert() and escape(). * They are easier to use. However, if you want to access colorcodes more * directly, look into the other functions. * * @category Console * @package Console_Color * @author Stefan Walk * @license http://www.opensource.org/licenses/mit-license.php MIT License * @link http://pear.php.net/package/Console_Color */ class Console_Color2 { protected $color_codes; public function __construct() { $this->setColorCodes( array( 'color' => array( 'black' => 30, 'red' => 31, 'green' => 32, 'brown' => 33, 'blue' => 34, 'purple' => 35, 'cyan' => 36, 'grey' => 37, 'yellow' => 33, ), 'style' => array( 'normal' => 0, 'bold' => 1, 'light' => 1, 'underscore' => 4, 'underline' => 4, 'blink' => 5, 'inverse' => 6, 'hidden' => 8, 'concealed' => 8, ), 'background' => array( 'black' => 40, 'red' => 41, 'green' => 42, 'brown' => 43, 'yellow' => 43, 'blue' => 44, 'purple' => 45, 'cyan' => 46, 'grey' => 47, ), ) ); }//end __construct() public function setColorCodes($color_codes) { $this->color_codes = $color_codes; }//end setColorCodes() public function getColorCodes() { return $this->color_codes; }//end getColorCodes() /** * Returns an ANSI-Controlcode * * Takes 1 to 3 Arguments: either 1 to 3 strings containing the name of the * FG Color, style and BG color, or one array with the indices color, style * or background. * * @param mixed $color Optional. * Either a string with the name of the foreground * color, or an array with the indices 'color', * 'style', 'background' and corresponding names as * values. * @param string $style Optional name of the style * @param string $background Optional name of the background color * * @return string */ public function color($color=null, $style=null, $background=null) { $colors = $this->getColorCodes(); if (is_array($color)) { $style = isset($color['style']) ? $color['style'] : null; $background = isset($color['background']) ? $color['background'] : null; $color = isset($color['color']) ? $color['color'] : null; } if ($color == 'reset') { return "\033[0m"; } $code = array(); if (isset($style)) { $code[] = $colors['style'][$style]; } if (isset($color)) { $code[] = $colors['color'][$color]; } if (isset($background)) { $code[] = $colors['background'][$background]; } if (empty($code)) { $code[] = 0; } $code = implode(';', $code); return "\033[{$code}m"; }//end color() // }}} /** * Returns a FG color controlcode * * @param string $name Name of controlcode * * @return string */ public function fgcolor($name) { $colors = $this->getColorCodes(); return "\033[".$colors['color'][$name].'m'; }//end fgcolor() /** * Returns a style controlcode * * @param string $name Name of controlcode * * @return string */ function bgcolor($name) { $colors = $this->getColorCodes(); return "\033[".$colors['background'][$name].'m'; }//end bgcolor() /** * Converts colorcodes in the format %y (for yellow) into ansi-control * codes. The conversion table is: ('bold' meaning 'light' on some * terminals). It's almost the same conversion table irssi uses. *
     *                  text      text            background
     *      ------------------------------------------------
     *      %k %K %0    black     dark grey       black
     *      %r %R %1    red       bold red        red
     *      %g %G %2    green     bold green      green
     *      %y %Y %3    yellow    bold yellow     yellow
     *      %b %B %4    blue      bold blue       blue
     *      %m %M %5    magenta   bold magenta    magenta
     *      %p %P       magenta (think: purple)
     *      %c %C %6    cyan      bold cyan       cyan
     *      %w %W %7    white     bold white      white
     *
     *      %F     Blinking, Flashing
     *      %U     Underline
     *      %8     Reverse
     *      %_,%9  Bold
     *
     *      %n     Resets the color
     *      %%     A single %
     * 
* First param is the string to convert, second is an optional flag if * colors should be used. It defaults to true, if set to false, the * colorcodes will just be removed (And %% will be transformed into %) * * @param string $string String to convert * @param boolean $colored Should the string be colored? * * @return string */ public function convert($string, $colored=true) { static $conversions = array( // static so the array doesn't get built // everytime // %y - yellow, and so on... {{{ '%y' => array( 'color' => 'yellow', 'style' => 'normal', ), '%g' => array( 'color' => 'green', 'style' => 'normal', ), '%b' => array( 'color' => 'blue', 'style' => 'normal', ), '%r' => array( 'color' => 'red', 'style' => 'normal', ), '%p' => array( 'color' => 'purple', 'style' => 'normal', ), '%m' => array( 'color' => 'purple', 'style' => 'normal', ), '%c' => array( 'color' => 'cyan', 'style' => 'normal', ), '%w' => array( 'color' => 'grey', 'style' => 'normal', ), '%k' => array( 'color' => 'black', 'style' => 'normal', ), '%n' => array('color' => 'reset' ), '%Y' => array( 'color' => 'yellow', 'style' => 'light', ), '%G' => array( 'color' => 'green', 'style' => 'light', ), '%B' => array( 'color' => 'blue', 'style' => 'light', ), '%R' => array( 'color' => 'red', 'style' => 'light', ), '%P' => array( 'color' => 'purple', 'style' => 'light', ), '%M' => array( 'color' => 'purple', 'style' => 'light', ), '%C' => array( 'color' => 'cyan', 'style' => 'light', ), '%W' => array( 'color' => 'grey', 'style' => 'light', ), '%K' => array( 'color' => 'black', 'style' => 'light', ), '%N' => array( 'color' => 'reset', 'style' => 'light', ), '%3' => array('background' => 'yellow'), '%2' => array('background' => 'green' ), '%4' => array('background' => 'blue' ), '%1' => array('background' => 'red' ), '%5' => array('background' => 'purple'), '%6' => array('background' => 'cyan' ), '%7' => array('background' => 'grey' ), '%0' => array('background' => 'black' ), // Don't use this, I can't stand flashing text '%F' => array('style' => 'blink'), '%U' => array('style' => 'underline'), '%8' => array('style' => 'inverse'), '%9' => array('style' => 'bold'), '%_' => array('style' => 'bold'), // }}} ); if ($colored) { $string = str_replace('%%', '% ', $string); foreach ($conversions as $key => $value) { $string = str_replace( $key, $this->color($value), $string ); } $string = str_replace('% ', '%', $string); } else { $string = preg_replace('/%((%)|.)/', '$2', $string); } return $string; }//end convert() /** * Escapes % so they don't get interpreted as color codes * * @param string $string String to escape * * @return string */ public function escape($string) { return str_replace('%', '%%', $string); }//end escape() /** * Strips ANSI color codes from a string * * @param string $string String to strip * * @acess public * @return string */ public function strip($string) { return preg_replace('/\033\[[\d;]+m/', '', $string); }//end strip() }//end class