MediaWiki REL1_33
Preprocessor.php
Go to the documentation of this file.
1<?php
25
29abstract class Preprocessor {
30
31 const CACHE_VERSION = 1;
32
36 protected $rules = [
37 '{' => [
38 'end' => '}',
39 'names' => [
40 2 => 'template',
41 3 => 'tplarg',
42 ],
43 'min' => 2,
44 'max' => 3,
45 ],
46 '[' => [
47 'end' => ']',
48 'names' => [ 2 => null ],
49 'min' => 2,
50 'max' => 2,
51 ],
52 '-{' => [
53 'end' => '}-',
54 'names' => [ 2 => null ],
55 'min' => 2,
56 'max' => 2,
57 ],
58 ];
59
67 protected function cacheSetTree( $text, $flags, $tree ) {
68 $config = RequestContext::getMain()->getConfig();
69
70 $length = strlen( $text );
71 $threshold = $config->get( 'PreprocessorCacheThreshold' );
72 if ( $threshold === false || $length < $threshold || $length > 1e6 ) {
73 return;
74 }
75
76 $cache = ObjectCache::getLocalClusterInstance();
77 $key = $cache->makeKey(
78 defined( 'static::CACHE_PREFIX' ) ? static::CACHE_PREFIX : static::class,
79 md5( $text ), $flags );
80 $value = sprintf( "%08d", static::CACHE_VERSION ) . $tree;
81
82 $cache->set( $key, $value, 86400 );
83
84 LoggerFactory::getInstance( 'Preprocessor' )
85 ->info( "Cached preprocessor output (key: $key)" );
86 }
87
96 protected function cacheGetTree( $text, $flags ) {
97 $config = RequestContext::getMain()->getConfig();
98
99 $length = strlen( $text );
100 $threshold = $config->get( 'PreprocessorCacheThreshold' );
101 if ( $threshold === false || $length < $threshold || $length > 1e6 ) {
102 return false;
103 }
104
105 $cache = ObjectCache::getLocalClusterInstance();
106
107 $key = $cache->makeKey(
108 defined( 'static::CACHE_PREFIX' ) ? static::CACHE_PREFIX : static::class,
109 md5( $text ), $flags );
110
111 $value = $cache->get( $key );
112 if ( !$value ) {
113 return false;
114 }
115
116 $version = intval( substr( $value, 0, 8 ) );
117 if ( $version !== static::CACHE_VERSION ) {
118 return false;
119 }
120
121 LoggerFactory::getInstance( 'Preprocessor' )
122 ->info( "Loaded preprocessor output from cache (key: $key)" );
123
124 return substr( $value, 8 );
125 }
126
132 abstract public function newFrame();
133
142 abstract public function newCustomFrame( $args );
143
150 abstract public function newPartNodeArray( $values );
151
160 abstract public function preprocessToObj( $text, $flags = 0 );
161}
162
166interface PPFrame {
167 const NO_ARGS = 1;
168 const NO_TEMPLATES = 2;
169 const STRIP_COMMENTS = 4;
170 const NO_IGNORE = 8;
172 const NO_TAGS = 32;
173
174 const RECOVER_ORIG = self::NO_ARGS | self::NO_TEMPLATES | self::NO_IGNORE |
175 self::RECOVER_COMMENTS | self::NO_TAGS;
176
179
189 public function newChild( $args = false, $title = false, $indexOffset = 0 );
190
198 public function cachedExpand( $key, $root, $flags = 0 );
199
206 public function expand( $root, $flags = 0 );
207
215 public function implodeWithFlags( $sep, $flags /*, ... */ );
216
223 public function implode( $sep /*, ... */ );
224
232 public function virtualImplode( $sep /*, ... */ );
233
242 public function virtualBracketedImplode( $start, $sep, $end /*, ... */ );
243
249 public function isEmpty();
250
255 public function getArguments();
256
261 public function getNumberedArguments();
262
267 public function getNamedArguments();
268
274 public function getArgument( $name );
275
282 public function loopCheck( $title );
283
288 public function isTemplate();
289
301 public function setVolatile( $flag = true );
302
312 public function isVolatile();
313
326 public function getTTL();
327
337 public function setTTL( $ttl );
338
344 public function getTitle();
345}
346
360interface PPNode {
366 public function getChildren();
367
373 public function getFirstChild();
374
379 public function getNextSibling();
380
387 public function getChildrenOfType( $type );
388
392 public function getLength();
393
399 public function item( $i );
400
414 public function getName();
415
423 public function splitArg();
424
430 public function splitExt();
431
436 public function splitHeading();
437}
and that you know you can do these things To protect your we need to make restrictions that forbid anyone to deny you these rights or to ask you to surrender the rights These restrictions translate to certain responsibilities for you if you distribute copies of the or if you modify it For if you distribute copies of such a whether gratis or for a you must give the recipients all the rights that you have You must make sure that receive or can get the source code And you must show them these terms so they know their rights We protect your rights with two and(2) offer you this license which gives you legal permission to copy
if( $line===false) $args
Definition cdb.php:64
PSR-3 logger instance factory.
preprocessToObj( $text, $flags=0)
Preprocess text to a PPNode.
cacheGetTree( $text, $flags)
Attempt to load a precomputed document tree for some given wikitext from the cache.
array $rules
Brace matching rules.
newPartNodeArray( $values)
Create a new custom node for programmatic use of parameter replacement as used in some extensions.
cacheSetTree( $text, $flags, $tree)
Store a document tree in the cache.
const CACHE_VERSION
newFrame()
Create a new top-level frame for expansion of a page.
newCustomFrame( $args)
Create a new custom frame for programmatic use of parameter replacement as used in some extensions.
this hook is for auditing only or null if authentication failed before getting that far or null if we can t even determine that When $user is not null
Definition hooks.txt:783
isEmpty()
Returns true if there are no arguments in this frame.
getArguments()
Returns all arguments of this frame.
const NO_TEMPLATES
const SUPPORTS_INDEX_OFFSET
This constant exists when $indexOffset is supported in newChild()
getTTL()
Get the TTL of the frame's output.
getArgument( $name)
Get an argument to this frame by name.
cachedExpand( $key, $root, $flags=0)
Expand a document tree node, caching the result on its parent with the given key.
const NO_TAGS
getNumberedArguments()
Returns all numbered arguments of this frame.
isVolatile()
Get the "volatile" flag.
virtualBracketedImplode( $start, $sep, $end)
Virtual implode with brackets.
const RECOVER_ORIG
implodeWithFlags( $sep, $flags)
Implode with flags for expand()
const RECOVER_COMMENTS
implode( $sep)
Implode with no flags specified.
const NO_ARGS
const NO_IGNORE
setTTL( $ttl)
Set the TTL of the output of this frame and all of its ancestors.
loopCheck( $title)
Returns true if the infinite loop check is OK, false if a loop is detected.
virtualImplode( $sep)
Makes an object that, when expand()ed, will be the same as one obtained with implode()
expand( $root, $flags=0)
Expand a document tree node.
isTemplate()
Return true if the frame is a template frame.
const STRIP_COMMENTS
getTitle()
Get a title of frame.
getNamedArguments()
Returns all named arguments of this frame.
newChild( $args=false, $title=false, $indexOffset=0)
Create a child frame.
setVolatile( $flag=true)
Set the "volatile" flag.
There are three types of nodes:
item( $i)
Returns an item of an array-type node.
getLength()
Returns the length of the array, or false if this is not an array-type node.
splitArg()
Split a "<part>" node into an associative array containing: name PPNode name index String index value...
splitExt()
Split an "<ext>" node into an associative array containing name, attr, inner and close All values in ...
getFirstChild()
Get the first child of a tree node.
getName()
Get the name of this node.
getChildren()
Get an array-type node containing the children of this node.
getChildrenOfType( $type)
Get all children of this tree node which have a given name.
splitHeading()
Split an "<h>" node.
getNextSibling()
Get the next sibling of any node.
$cache
Definition mcc.php:33
The wiki should then use memcached to cache various data To use multiple just add more items to the array To increase the weight of a make its entry a array("192.168.0.1:11211", 2))