From 3bd281fa2784048e29c6004b90bcd203733e4e32 Mon Sep 17 00:00:00 2001 From: Nathan Guse Date: Mon, 24 Jun 2013 11:18:29 -0500 Subject: [feature/twig] Event template tag PHPBB3-11598 --- phpBB/includes/template/twig/tokenparser/event.php | 58 +++++++--------------- 1 file changed, 19 insertions(+), 39 deletions(-) (limited to 'phpBB/includes/template/twig/tokenparser') diff --git a/phpBB/includes/template/twig/tokenparser/event.php b/phpBB/includes/template/twig/tokenparser/event.php index 27a8350af1..03810454ed 100644 --- a/phpBB/includes/template/twig/tokenparser/event.php +++ b/phpBB/includes/template/twig/tokenparser/event.php @@ -1,49 +1,29 @@ - * {% include 'header.html' %} - * Body - * {% include 'footer.html' %} - * - */ -class phpbb_template_twig_tokenparser_event extends Twig_TokenParser_Include +* +* @package phpBB3 +* @copyright (c) 2013 phpBB Group +* @license http://opensource.org/licenses/gpl-2.0.php GNU General Public License v2 +* +*/ + +class phpbb_template_twig_tokenparser_event extends Twig_TokenParser { - protected function parseArguments() + /** + * Parses a token and returns a node. + * + * @param Twig_Token $token A Twig_Token instance + * + * @return Twig_NodeInterface A Twig_NodeInterface instance + */ + public function parse(Twig_Token $token) { - $stream = $this->parser->getStream(); - - $ignoreMissing = true; - - $variables = null; - if ($stream->test(Twig_Token::NAME_TYPE, 'with')) { - $stream->next(); - - $variables = $this->parser->getExpressionParser()->parseExpression(); - } - - $only = false; - if ($stream->test(Twig_Token::NAME_TYPE, 'only')) { - $stream->next(); - - $only = true; - } + $expr = $this->parser->getExpressionParser()->parseExpression(); + $stream = $this->parser->getStream(); $stream->expect(Twig_Token::BLOCK_END_TYPE); - return array($variables, $only, $ignoreMissing); + return new phpbb_template_twig_node_event($expr, $this->parser->getEnvironment(), $token->getLine(), $this->getTag()); } /** -- cgit v1.2.1