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
|
<?php
/**
* Info Indexmenu tag: Tag a page with a sort number.
*
* @license GPL 2 (http://www.gnu.org/licenses/gpl.html)
* @author Samuele Tognini <samuele@netsons.org>
*
*/
if(!defined('DOKU_INC')) define('DOKU_INC',realpath(dirname(__FILE__).'/../../').'/');
if(!defined('DOKU_PLUGIN')) define('DOKU_PLUGIN',DOKU_INC.'lib/plugins/');
require_once(DOKU_PLUGIN.'syntax.php');
/**
* All DokuWiki plugins to extend the parser/rendering mechanism
* need to inherit from this class
*/
class syntax_plugin_indexmenu_tag extends DokuWiki_Syntax_Plugin {
/**
* return some info
*/
function getInfo(){
return array(
'author' => 'Samuele Tognini',
'email' => 'samuele@netsons.org',
'date' => rtrim(io_readFile(DOKU_PLUGIN.'indexmenu/VERSION.txt')),
'name' => 'Indexmenu tag',
'desc' => 'Indexmenu tag plugin.',
'url' => 'http://wiki.splitbrain.org/plugin:indexmenu'
);
}
/**
* What kind of syntax are we?
*/
function getType(){
return 'substition';
}
/**
* Where to sort in?
*/
function getSort(){
return 139;
}
/**
* Connect pattern to lexer
*/
function connectTo($mode) {
$this->Lexer->addSpecialPattern('{{indexmenu_n>.+?}}',$mode,'plugin_indexmenu_tag');
}
/**
* Handle the match
*/
function handle($match, $state, $pos, &$handler){
$match = substr($match,14,-2);
return array($match);
}
/**
* Render output
*/
function render($mode, &$renderer, $data) {
if (is_numeric($data[0])) $renderer->meta['indexmenu_n'] = $data[0];;
}
}
|