File indexing completed on 2025-01-19 05:20:53
0001 <?php 0002 0003 // OUT OF DATE, NEEDS UPDATING! 0004 // USE XMLWRITER! 0005 0006 class HTMLPurifier_Printer 0007 { 0008 0009 /** 0010 * For HTML generation convenience funcs. 0011 * @type HTMLPurifier_Generator 0012 */ 0013 protected $generator; 0014 0015 /** 0016 * For easy access. 0017 * @type HTMLPurifier_Config 0018 */ 0019 protected $config; 0020 0021 /** 0022 * Initialize $generator. 0023 */ 0024 public function __construct() 0025 { 0026 } 0027 0028 /** 0029 * Give generator necessary configuration if possible 0030 * @param HTMLPurifier_Config $config 0031 */ 0032 public function prepareGenerator($config) 0033 { 0034 $all = $config->getAll(); 0035 $context = new HTMLPurifier_Context(); 0036 $this->generator = new HTMLPurifier_Generator($config, $context); 0037 } 0038 0039 /** 0040 * Main function that renders object or aspect of that object 0041 * @note Parameters vary depending on printer 0042 */ 0043 // function render() {} 0044 0045 /** 0046 * Returns a start tag 0047 * @param string $tag Tag name 0048 * @param array $attr Attribute array 0049 * @return string 0050 */ 0051 protected function start($tag, $attr = array()) 0052 { 0053 return $this->generator->generateFromToken( 0054 new HTMLPurifier_Token_Start($tag, $attr ? $attr : array()) 0055 ); 0056 } 0057 0058 /** 0059 * Returns an end tag 0060 * @param string $tag Tag name 0061 * @return string 0062 */ 0063 protected function end($tag) 0064 { 0065 return $this->generator->generateFromToken( 0066 new HTMLPurifier_Token_End($tag) 0067 ); 0068 } 0069 0070 /** 0071 * Prints a complete element with content inside 0072 * @param string $tag Tag name 0073 * @param string $contents Element contents 0074 * @param array $attr Tag attributes 0075 * @param bool $escape whether or not to escape contents 0076 * @return string 0077 */ 0078 protected function element($tag, $contents, $attr = array(), $escape = true) 0079 { 0080 return $this->start($tag, $attr) . 0081 ($escape ? $this->escape($contents) : $contents) . 0082 $this->end($tag); 0083 } 0084 0085 /** 0086 * @param string $tag 0087 * @param array $attr 0088 * @return string 0089 */ 0090 protected function elementEmpty($tag, $attr = array()) 0091 { 0092 return $this->generator->generateFromToken( 0093 new HTMLPurifier_Token_Empty($tag, $attr) 0094 ); 0095 } 0096 0097 /** 0098 * @param string $text 0099 * @return string 0100 */ 0101 protected function text($text) 0102 { 0103 return $this->generator->generateFromToken( 0104 new HTMLPurifier_Token_Text($text) 0105 ); 0106 } 0107 0108 /** 0109 * Prints a simple key/value row in a table. 0110 * @param string $name Key 0111 * @param mixed $value Value 0112 * @return string 0113 */ 0114 protected function row($name, $value) 0115 { 0116 if (is_bool($value)) { 0117 $value = $value ? 'On' : 'Off'; 0118 } 0119 return 0120 $this->start('tr') . "\n" . 0121 $this->element('th', $name) . "\n" . 0122 $this->element('td', $value) . "\n" . 0123 $this->end('tr'); 0124 } 0125 0126 /** 0127 * Escapes a string for HTML output. 0128 * @param string $string String to escape 0129 * @return string 0130 */ 0131 protected function escape($string) 0132 { 0133 $string = HTMLPurifier_Encoder::cleanUTF8($string); 0134 $string = htmlspecialchars($string, ENT_COMPAT, 'UTF-8'); 0135 return $string; 0136 } 0137 0138 /** 0139 * Takes a list of strings and turns them into a single list 0140 * @param string[] $array List of strings 0141 * @param bool $polite Bool whether or not to add an end before the last 0142 * @return string 0143 */ 0144 protected function listify($array, $polite = false) 0145 { 0146 if (empty($array)) { 0147 return 'None'; 0148 } 0149 $ret = ''; 0150 $i = count($array); 0151 foreach ($array as $value) { 0152 $i--; 0153 $ret .= $value; 0154 if ($i > 0 && !($polite && $i == 1)) { 0155 $ret .= ', '; 0156 } 0157 if ($polite && $i == 1) { 0158 $ret .= 'and '; 0159 } 0160 } 0161 return $ret; 0162 } 0163 0164 /** 0165 * Retrieves the class of an object without prefixes, as well as metadata 0166 * @param object $obj Object to determine class of 0167 * @param string $sec_prefix Further prefix to remove 0168 * @return string 0169 */ 0170 protected function getClass($obj, $sec_prefix = '') 0171 { 0172 static $five = null; 0173 if ($five === null) { 0174 $five = version_compare(PHP_VERSION, '5', '>='); 0175 } 0176 $prefix = 'HTMLPurifier_' . $sec_prefix; 0177 if (!$five) { 0178 $prefix = strtolower($prefix); 0179 } 0180 $class = str_replace($prefix, '', get_class($obj)); 0181 $lclass = strtolower($class); 0182 $class .= '('; 0183 switch ($lclass) { 0184 case 'enum': 0185 $values = array(); 0186 foreach ($obj->valid_values as $value => $bool) { 0187 $values[] = $value; 0188 } 0189 $class .= implode(', ', $values); 0190 break; 0191 case 'css_composite': 0192 $values = array(); 0193 foreach ($obj->defs as $def) { 0194 $values[] = $this->getClass($def, $sec_prefix); 0195 } 0196 $class .= implode(', ', $values); 0197 break; 0198 case 'css_multiple': 0199 $class .= $this->getClass($obj->single, $sec_prefix) . ', '; 0200 $class .= $obj->max; 0201 break; 0202 case 'css_denyelementdecorator': 0203 $class .= $this->getClass($obj->def, $sec_prefix) . ', '; 0204 $class .= $obj->element; 0205 break; 0206 case 'css_importantdecorator': 0207 $class .= $this->getClass($obj->def, $sec_prefix); 0208 if ($obj->allow) { 0209 $class .= ', !important'; 0210 } 0211 break; 0212 } 0213 $class .= ')'; 0214 return $class; 0215 } 0216 } 0217 0218 // vim: et sw=4 sts=4