summaryrefslogtreecommitdiff
path: root/includes/pear/Text/Wiki/Parse/BBCode/Subscript.php
blob: c115d692165e8ab83d4f0ef93fe352f8de55ec93 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
<?php
/* vim: set expandtab tabstop=4 shiftwidth=4 softtabstop=4 foldmethod=marker */

// {{{ Header

/**
 * BBCode: Parses for subscript text.
 *
 * This class implements a Text_Wiki_Rule to find source text marked for
 * strong emphasis (subscript) text as defined by text surrounded by
 * [sub] ... [/sub] On parsing, the text itself is left in place, but
 * the starting and ending tags are replaced with tokens.
 *
 * PHP versions 4 and 5
 *
 * @category Text
 * @package Text_Wiki
 * @author Firman Wandayandi <firman@php.net>
 * @copyright 2005 bertrand Gugger
 * @license http://www.gnu.org/copyleft/lgpl.html
 *          GNU Lesser General Public License, version 2.1
 * @version CVS: $Id: Subscript.php,v 1.2 2006/02/21 22:47:53 toggg Exp $
 */

// }}}
// {{{ Class: Text_Wiki_Parse_Subscript

/**
 * Subscript text rule parser class for BBCode.
 *
 * @category Text
 * @package Text_Wiki
 * @author Firman Wandayandi <firman@php.net>
 * @copyright 2005 bertrand Gugger
 * @license http://www.gnu.org/copyleft/lgpl.html
 *          GNU Lesser General Public License, version 2.1
 * @version Release: @package_version@
 */
class Text_Wiki_Parse_Subscript extends Text_Wiki_Parse
{
    // {{{ Properties

    /**
     * The regular expression used to parse the source text and find
     * matches conforming to this rule. Used by the parse() method.
     *
     * @access public
     * @var string
     * @see parse()
     */
    var $regex = "#\[sub](.*?)\[/sub]#i";

    // }}}
    // {{{ process()

    /**
     * Generates a replacement for the matched text.  Token options are:
     * - 'type' => ['start'|'end'] The starting or ending point of the
     * emphasized text.  The text itself is left in the source.
     *
     * @param array &$matches The array of matches from parse().
     * @return A pair of delimited tokens to be used as a placeholder in
     * the source text surrounding the text to be emphasized.
     * @access public
     */
    function process(&$matches)
    {
        $start = $this->wiki->addToken($this->rule, array("type" => "start"));
        $end = $this->wiki->addToken($this->rule, array("type" => "end"));
        return $start . $matches[1] . $end;
    }

    // }}}
}

// }}}

/*
 * Local variables:
 * mode: php
 * tab-width: 4
 * c-basic-offset: 4
 * c-hanging-comment-ender-p: nil
 * End:
 */