Source for file phpcode.php
Documentation is available at phpcode.php
/* vim: set expandtab tabstop=4 shiftwidth=4: */
// +----------------------------------------------------------------------+
// +----------------------------------------------------------------------+
// | Copyright (c) 1997-2003 The PHP Group |
// +----------------------------------------------------------------------+
// | This source file is subject to version 2.0 of the PHP license, |
// | that is bundled with this package in the file LICENSE, and is |
// | available through the world-wide-web at |
// | http://www.php.net/license/2_02.txt. |
// | If you did not receive a copy of the PHP license and are unable to |
// | obtain it through the world-wide-web, please send a note to |
// | license@php.net so we can mail you a copy immediately. |
// +----------------------------------------------------------------------+
// | Authors: Paul M. Jones <pmjones@ciaweb.net> |
// +----------------------------------------------------------------------+
// $Id: phpcode.php,v 1.1 2004/01/04 01:35:23 pmjones Exp $
* This class implements a Text_Wiki_Rule to find sections marked as code
* examples. Blocks are marked as the string <code> on a line by itself,
* followed by the inline code example, and terminated with the string
* </code> on a line by itself. The code example is run through the
* native PHP highlight_string() function to colorize it, then surrounded
* with <pre>...</pre> tags when rendered as XHTML.
* @author Paul M. Jones <pmjones@ciaweb.net>
* The regular expression used to find source text matching this
var $regex = '/^(\<php\>)\n(.+)\n(\<\/php\>)(\s|$)/Umsi';
* Generates a token entry for the matched text. Token options are:
* 'text' => The full matched text, not including the <code></code> tags.
* @param array &$matches The array of matches from parse().
* @return A delimited token number to be used as a placeholder in
$options = array ('text' => $matches[2 ]);
return $this->addToken($options) . $matches[4 ];
* Renders a token into text matching the requested format.
* @param array $options The "options" portion of the token (second
* @return string The text rendered from the token options.
$text = "<?php\n" . $options['text'] . "\n?>"; // <?php
// convert tabs to four spaces
// colorize the code block (also converts HTML entities and adds
// <code>...</code> tags)
// replace <br /> tags with simple newlines
// replace non-breaking space with simple spaces
// get rid of the last newline inside the code block
// (becuase higlight_string puts one there)
if (substr($text, -8 ) == "\n</code>") {
$text = substr($text, 0 , -8 ) . "</code>";
return " \n<pre>$text</pre>\n";
Documentation generated on Mon, 11 Mar 2019 10:14:14 -0400 by phpDocumentor 1.4.4. PEAR Logo Copyright © PHP Group 2004.
|