# (with modified parser callback and attribute additions)
#
# Anyone is allowed to use this code for any purpose.
#
# To install, copy the extension to your extensions directory and add line
# include("extensions/Poem.php");
# to the bottom of your LocalSettings.php
#
# To use, put some text between tags
#
# For more information see its page at
# http://meta.wikimedia.org/wiki/Poem_Extension
$wgHooks['ParserFirstCallInit'][] = 'wfPoemExtension';
$wgExtensionCredits['parserhook'][] = array(
'path' => __FILE__,
'name' => 'Poem',
'author' => array( 'Nikola Smolenski', 'Brion Vibber', 'Steve Sanbeg' ),
'url' => 'http://www.mediawiki.org/wiki/Extension:Poem',
'description' => 'Adds <poem> tag for poem formatting',
'descriptionmsg' => 'poem-desc',
);
$wgParserTestFiles[] = dirname( __FILE__ ) . "/poemParserTests.txt";
$wgExtensionMessagesFiles['Poem'] = dirname(__FILE__) . '/Poem.i18n.php';
function wfPoemExtension( &$parser ) {
$parser->setHook("poem","PoemExtension");
return true;
}
function PoemExtension( $in, $param=array(), $parser=null ) {
/* using newlines in the text will cause the parser to add
tags,
* which may not be desired in some cases
*/
$nl = isset( $param['compact'] ) ? '' : "\n";
if( method_exists( $parser, 'recursiveTagParse' ) ) {
//new methods in 1.8 allow nesting in .
$tag = $parser->insertStripItem( "
", $parser->mStripState );
$text = preg_replace(
array( "/^\n/", "/\n$/D", "/\n/", "/^( +)/me" ),
array( "", "", "$tag\n", "str_replace(' ',' ','\\1')" ),
$in );
$text = $parser->recursiveTagParse( $text );
} else {
$text = preg_replace(
array( "/^\n/", "/\n$/D", "/\n/", "/^( +)/me" ),
array( "", "", "
\n", "str_replace(' ',' ','\\1')" ),
$in );
$ret = $parser->parse(
$text,
$parser->getTitle(),
$parser->getOptions(),
// We begin at line start
true,
// Important, otherwise $this->clearState()
// would get run every time [ or
// is called, fucking the whole
// thing up.
false
);
$text = $ret->getText();
}
global $wgVersion;
if( version_compare( $wgVersion, "1.7alpha" ) >= 0 ) {
// Pass HTML attributes through to the output.
$attribs = Sanitizer::validateTagAttributes( $param, 'div' );
} else {
// Can't guarantee safety on 1.6 or older.
$attribs = array();
}
// Wrap output in a ] with "poem" class.
if( isset( $attribs['class'] ) ) {
$attribs['class'] = 'poem ' . $attribs['class'];
} else {
$attribs['class'] = 'poem';
}
return Xml::openElement( 'div', $attribs ) .
$nl .
trim( $text ) .
"$nl
";
}