239 lines
6.8 KiB
PHP
239 lines
6.8 KiB
PHP
|
<?php
|
||
|
/* vim: set expandtab tabstop=4 shiftwidth=4 softtabstop=4: */
|
||
|
/**
|
||
|
* BB code renderer.
|
||
|
*
|
||
|
* This BB renderer produces BB code, ready to be pasted in bulletin boards and
|
||
|
* other applications that accept BB code. Based on the HTML renderer by Andrey Demenev.
|
||
|
*
|
||
|
* LICENSE: This source file is subject to version 3.0 of the PHP license
|
||
|
* that is available through the world-wide-web at the following URI:
|
||
|
* http://www.php.net/license/3_0.txt. If you did not receive a copy of
|
||
|
* the PHP License and are unable to obtain it through the web, please
|
||
|
* send a note to license@php.net so we can mail you a copy immediately.
|
||
|
*
|
||
|
* @category Text
|
||
|
* @package Text_Highlighter
|
||
|
* @author Stoyan Stefanov <ssttoo@gmail.com>
|
||
|
* @copyright 2005 Stoyan Stefanov
|
||
|
* @license http://www.php.net/license/3_0.txt PHP License
|
||
|
* @version CVS: $Id$
|
||
|
* @link http://pear.php.net/package/Text_Highlighter
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
* @ignore
|
||
|
*/
|
||
|
|
||
|
require_once 'Text/Highlighter/Renderer.php';
|
||
|
|
||
|
/**
|
||
|
* BB code renderer, based on Andrey Demenev's HTML renderer.
|
||
|
*
|
||
|
* Elements of $options argument of constructor (each being optional):
|
||
|
*
|
||
|
* - 'numbers' - Line numbering TRUE or FALSE
|
||
|
* - 'tabsize' - Tab size, default is 4
|
||
|
* - 'bb_tags' - An array containing three BB tags, see below
|
||
|
* - 'tag_brackets' - An array that conains opening and closing tags, [ and ]
|
||
|
* - 'colors' - An array with all the colors to be used for highlighting
|
||
|
*
|
||
|
* The default BB tags are:
|
||
|
* - 'color' => 'color'
|
||
|
* - 'list' => 'list'
|
||
|
* - 'list_item' => '*'
|
||
|
*
|
||
|
* The default colors for the highlighter are:
|
||
|
* - 'default' => 'Black',
|
||
|
* - 'code' => 'Gray',
|
||
|
* - 'brackets' => 'Olive',
|
||
|
* - 'comment' => 'Orange',
|
||
|
* - 'mlcomment' => 'Orange',
|
||
|
* - 'quotes' => 'Darkred',
|
||
|
* - 'string' => 'Red',
|
||
|
* - 'identifier' => 'Blue',
|
||
|
* - 'builtin' => 'Teal',
|
||
|
* - 'reserved' => 'Green',
|
||
|
* - 'inlinedoc' => 'Blue',
|
||
|
* - 'var' => 'Darkblue',
|
||
|
* - 'url' => 'Blue',
|
||
|
* - 'special' => 'Navy',
|
||
|
* - 'number' => 'Maroon',
|
||
|
* - 'inlinetags' => 'Blue',
|
||
|
*
|
||
|
*
|
||
|
* @author Stoyan Stefanov <ssttoo@gmail.com>
|
||
|
* @category Text
|
||
|
* @package Text_Highlighter
|
||
|
* @copyright 20045 Stoyan Stefanov
|
||
|
* @license http://www.php.net/license/3_0.txt PHP License
|
||
|
* @version Release: 0.5.0
|
||
|
* @link http://pear.php.net/package/Text_Highlighter
|
||
|
*/
|
||
|
|
||
|
class Text_Highlighter_Renderer_BB extends Text_Highlighter_Renderer_Array
|
||
|
{
|
||
|
|
||
|
/**#@+
|
||
|
* @access private
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
* Line numbering - will use the specified BB tag for listings
|
||
|
*
|
||
|
* @var boolean
|
||
|
*/
|
||
|
var $_numbers = false;
|
||
|
|
||
|
/**
|
||
|
* BB tags to be used
|
||
|
*
|
||
|
* @var array
|
||
|
*/
|
||
|
var $_bb_tags = array (
|
||
|
'color' => 'color',
|
||
|
'list' => 'list',
|
||
|
'list_item' => '*',
|
||
|
'code' => 'code',
|
||
|
);
|
||
|
|
||
|
/**
|
||
|
* BB brackets - [ and ]
|
||
|
*
|
||
|
* @var array
|
||
|
*/
|
||
|
var $_tag_brackets = array ('start' => '[', 'end' => ']');
|
||
|
|
||
|
/**
|
||
|
* Colors map
|
||
|
*
|
||
|
* @var boolean
|
||
|
*/
|
||
|
var $_colors = array(
|
||
|
'default' => 'Black',
|
||
|
'code' => 'Gray',
|
||
|
'brackets' => 'Olive',
|
||
|
'comment' => 'Orange',
|
||
|
'mlcomment' => 'Orange',
|
||
|
'quotes' => 'Darkred',
|
||
|
'string' => 'Red',
|
||
|
'identifier' => 'Blue',
|
||
|
'builtin' => 'Teal',
|
||
|
'reserved' => 'Green',
|
||
|
'inlinedoc' => 'Blue',
|
||
|
'var' => 'Darkblue',
|
||
|
'url' => 'Blue',
|
||
|
'special' => 'Navy',
|
||
|
'number' => 'Maroon',
|
||
|
'inlinetags' => 'Blue',
|
||
|
);
|
||
|
|
||
|
/**#@-*/
|
||
|
|
||
|
/**
|
||
|
* Resets renderer state
|
||
|
*
|
||
|
* @access protected
|
||
|
*
|
||
|
*
|
||
|
* Descendents of Text_Highlighter call this method from the constructor,
|
||
|
* passing $options they get as parameter.
|
||
|
*/
|
||
|
function reset()
|
||
|
{
|
||
|
parent::reset();
|
||
|
if (isset($this->_options['numbers'])) {
|
||
|
$this->_numbers = $this->_options['numbers'];
|
||
|
}
|
||
|
if (isset($this->_options['bb_tags'])) {
|
||
|
$this->_bb_tags = array_merge($this->_bb_tags, $this->_options['bb_tags']);
|
||
|
}
|
||
|
if (isset($this->_options['tag_brackets'])) {
|
||
|
$this->_tag_brackets = array_merge($this->_tag_brackets, $this->_options['tag_brackets']);
|
||
|
}
|
||
|
if (isset($this->_options['colors'])) {
|
||
|
$this->_colors = array_merge($this->_colors, $this->_options['colors']);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
|
||
|
/**
|
||
|
* Signals that no more tokens are available
|
||
|
*
|
||
|
* @abstract
|
||
|
* @access public
|
||
|
*
|
||
|
*/
|
||
|
function finalize()
|
||
|
{
|
||
|
|
||
|
// get parent's output
|
||
|
parent::finalize();
|
||
|
$output = parent::getOutput();
|
||
|
|
||
|
$bb_output = '';
|
||
|
|
||
|
$color_start = $this->_tag_brackets['start'] . $this->_bb_tags['color'] . '=%s' . $this->_tag_brackets['end'];
|
||
|
$color_end = $this->_tag_brackets['start'] . '/' . $this->_bb_tags['color'] . $this->_tag_brackets['end'];
|
||
|
|
||
|
// loop through each class=>content pair
|
||
|
foreach ($output AS $token) {
|
||
|
|
||
|
if ($this->_enumerated) {
|
||
|
$class = $token[0];
|
||
|
$content = $token[1];
|
||
|
} else {
|
||
|
$key = key($token);
|
||
|
$class = $key;
|
||
|
$content = $token[$key];
|
||
|
}
|
||
|
|
||
|
$iswhitespace = ctype_space($content);
|
||
|
if (!$iswhitespace && !empty($this->_colors[$class])) {
|
||
|
$bb_output .= sprintf($color_start, $this->_colors[$class]);
|
||
|
$bb_output .= $content;
|
||
|
$bb_output .= $color_end;
|
||
|
} else {
|
||
|
$bb_output .= $content;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
if ($this->_numbers) {
|
||
|
|
||
|
$item_tag = $this->_tag_brackets['start'] .
|
||
|
$this->_bb_tags['list_item'] .
|
||
|
$this->_tag_brackets['end'];
|
||
|
$this->_output = $item_tag . str_replace("\n", "\n". $item_tag .' ', $bb_output);
|
||
|
$this->_output = $this->_tag_brackets['start'] .
|
||
|
$this->_bb_tags['list'] .
|
||
|
$this->_tag_brackets['end'] .
|
||
|
$this->_output .
|
||
|
$this->_tag_brackets['start'] .
|
||
|
'/'.
|
||
|
$this->_bb_tags['list'] .
|
||
|
$this->_tag_brackets['end']
|
||
|
;
|
||
|
} else {
|
||
|
$this->_output = $this->_tag_brackets['start'] .
|
||
|
$this->_bb_tags['code'] .
|
||
|
$this->_tag_brackets['end'] .
|
||
|
$bb_output .
|
||
|
$this->_tag_brackets['start'] .
|
||
|
'/' .
|
||
|
$this->_bb_tags['code'] .
|
||
|
$this->_tag_brackets['end'];
|
||
|
}
|
||
|
}
|
||
|
|
||
|
}
|
||
|
|
||
|
/*
|
||
|
* Local variables:
|
||
|
* tab-width: 4
|
||
|
* c-basic-offset: 4
|
||
|
* c-hanging-comment-ender-p: nil
|
||
|
* End:
|
||
|
*/
|
||
|
|
||
|
?>
|