--- /dev/null Thu Jan 01 00:00:00 1970 +0000
+++ b/includes/wikiengine/Parse/Mediawiki/Anchor.php Wed Jun 13 16:07:17 2007 -0400
@@ -0,0 +1,87 @@
+<?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;
+ }
+}
+?>