author | Dan |
Sat, 08 Nov 2008 22:32:43 -0500 | |
changeset 720 | e2762777b170 |
parent 1 | fe660c52c48f |
permissions | -rw-r--r-- |
<?php /** * * Parses for anchor targets. * * @category Text * * @package Text_Wiki * * @author Manuel Holtgrewe <purestorm at ggnore dot net> * * @author Paul M. Jones <pmjones@php.net> * * @license LGPL * * @version $Id: Anchor.php,v 1.3 2005/02/23 17:38:29 pmjones Exp $ * */ /** * * This class implements a Text_Wiki_Parse to add an anchor target name * in the wiki page. * * @author Manuel Holtgrewe <purestorm at ggnore dot net> * * @author Paul M. Jones <pmjones at ciaweb dot net> * * @category Text * * @package Text_Wiki * */ class Text_Wiki_Parse_Anchor extends Text_Wiki_Parse { /** * * The regular expression used to find source text matching this * rule. Looks like a macro: [[# anchor_name]] * * @access public * * @var string * */ var $regex = '/(\[\[# )([-_A-Za-z0-9.]+?)( .+)?(\]\])/i'; /** * * Generates a token entry for the matched text. Token options are: * * 'text' => The full matched text, not including the <code></code> tags. * * @access public * * @param array &$matches The array of matches from parse(). * * @return A delimited token number to be used as a placeholder in * the source text. * */ function process(&$matches) { $name = $matches[2]; $text = $matches[3]; $start = $this->wiki->addToken( $this->rule, array('type' => 'start', 'name' => $name) ); $end = $this->wiki->addToken( $this->rule, array('type' => 'end', 'name' => $name) ); // done, place the script output directly in the source return $start . trim($text) . $end; } } ?>