ref: e731b2ba2cdb6f3f38b701a19dc5c035a2232371
dir: /examples/includes/vp8_doc_tools.php/
#!/usr/bin/env php <?php /** * vp8_doc_tools.php - Functions used when generating the * On2 VP8 user documentation. * * Requirements * * PHP Markdown Extra * http://michelf.com/projects/php-markdown/extra/ * * PHP SmartyPants * http://michelf.com/projects/php-smartypants/ * * GeSHI * http://qbnz.com/highlighter/ * * ASCIIMathPHP * http://tinyurl.com/asciimathphp * * HTML::Toc * http://search.cpan.org/~fvulto/HTML-Toc-0.91/Toc.pod * * * April 2009 - Lou Quillio <[email protected]> * **********************************************************/ // Includes include_once('PHP-Markdown-Extra-1.2.3/markdown.php'); include_once('PHP-SmartyPants-1.5.1e/smartypants.php'); include_once('ASCIIMathPHP-2.0/ASCIIMathPHP-2.0.cfg.php'); require_once('ASCIIMathPHP-2.0/ASCIIMathPHP-2.0.class.php'); include_once('geshi/geshi.php'); // Paths and Scripts $geshi_lang = 'geshi/geshi/'; // GeSHi language files $toc_script = './do_toc.pl'; /** * ASCIIMathML parser * http://tinyurl.com/ASCIIMathPHP * * @PARAM mtch_arr array - Array of ASCIIMath expressions * as returned by preg_replace_callback([pattern]). First * dimension is the full matched string (with delimiter); * 2nd dimension is the undelimited contents (typically * a capture group). * **********************************************************/ function ASCIIMathPHPCallback($mtch_arr) { $txt = trim($mtch_arr[1]); static $asciimath; if (!isset($asciimath)) $asciimath = new ASCIIMathPHP($symbol_arr); $math_attr_arr = array('displaystyle' => 'true'); $asciimath->setExpr($txt); $asciimath->genMathML($math_attr_arr); return($asciimath->getMathML()); } /** * fix_asciiMath() * * ASCIIMath pretty-prints its output, with linefeeds * and tabs. Causes unexpected behavior in some renderers. * This flattens <math> blocks. * * @PARAM page_body str - The <body> element of an * XHTML page to transform. * **********************************************************/ function fix_asciiMath($page_body) { $out = FALSE; // Remove linefeeds and whitespace in <math> elements $tags_bad = array('/(<math.*?>)\n*\s*/' , '/(<mstyle.*?>)\n*\s*/' , '/(<\/mstyle>)\n*\s*/' , '/(<mrow.*?>)\n*\s*/' , '/(<\/mrow>)\n*\s*/' , '/(<mo.*?>)\n*\s*/' , '/(<\/mo>)\n*\s*/' , '/(<mi.*?>)\n*\s*/' , '/(<\/mi>)\n*\s*/' , '/(<mn.*?>)\n*\s*/' , '/(<\/mn>)\n*\s*/' , '/(<mtext.*?>)\n*\s*/' , '/(<\/mtext>)\n*\s*/' , '/(<msqrt.*?>)\n*\s*/' , '/(<\/msqrt>)\n*\s*/' , '/(<mfrac.*?>)\n*\s*/' , '/(<\/mfrac>)\n*\s*/' ); $tags_good = array( '$1' , '$1' , '$1' , '$1' , '$1' , '$1' , '$1' , '$1' , '$1' , '$1' , '$1' , '$1' , '$1' , '$1' , '$1' , '$1' , '$1' ); $out = preg_replace($tags_bad, $tags_good, $page_body); return $out; } /** * do_geshi() - Performs GeSHi transforms on XHTML blobs * * @param $blob str - The blob to transform * @param $open str - Opening expression to match * @param $close str - Closing expression to match * @param $lang str - Language file to use * **********************************************************/ function do_geshi($blob, $open = '<pre>', $close = '</pre>', $lang = 'c') { $out = FALSE; $regexp = '|' . $open . '(.*?)' . $close . '|si'; echo $regexp . "\n\n"; while (preg_match($regexp, $blob, $matches)) { $geshi = new GeSHi($matches[1], $lang); $geshi->set_language_path($geshi_lang); $blob_new = $geshi->parse_code(); // Strip annoying final <br /> $blob_new = preg_replace('/\n <\/pre>/', '</pre>' , $blob_new); // Fix annoying GeSHI-injected attributes $blob_new = preg_replace('/<pre.*>/i', '<pre>' , $blob_new); $blob = preg_replace($regexp, $blob_new, $blob, 1); unset($geshi); } return $out; } /** * prep_dd_codeblocks() * * I'm _so_ not proud of this, but don't have time to * write a proper regex. * * @TODO - Write that regex. * **********************************************************/ /* function prep_dd_codeblocks($page_body) { $out = FALSE; $toggle = 0; $regexp = '/~{3,}/'; while (preg_match($regexp, $page_body)) { if ($toggle == 0) { $regexp = '/:\s*~{3,}\s*\n/'; $page_body = preg_replace($regexp, ': <pre><code>', $page_body, 1); $toggle = 1; } else { $regexp = '/\n\s*~{3,}/'; $page_body = preg_replace($regexp, '</code></pre>', $page_body, 1); $toggle = 0; } } // One more time $regexp = '/\n\s*~{3,}/'; $page_body = preg_replace($regexp, '</code></pre>', $page_body, 1); $out = $page_body; return $out; } */