TYPO3 API  SVNRelease
InterceptorInterface.php
Go to the documentation of this file.
00001 <?php
00002 
00003 /*                                                                        *
00004  * This script belongs to the FLOW3 package "Fluid".                      *
00005  *                                                                        *
00006  * It is free software; you can redistribute it and/or modify it under    *
00007  * the terms of the GNU Lesser General Public License as published by the *
00008  * Free Software Foundation, either version 3 of the License, or (at your *
00009  * option) any later version.                                             *
00010  *                                                                        *
00011  * This script is distributed in the hope that it will be useful, but     *
00012  * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHAN-    *
00013  * TABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Lesser       *
00014  * General Public License for more details.                               *
00015  *                                                                        *
00016  * You should have received a copy of the GNU Lesser General Public       *
00017  * License along with the script.                                         *
00018  * If not, see http://www.gnu.org/licenses/lgpl.html                      *
00019  *                                                                        *
00020  * The TYPO3 project - inspiring people to share!                         *
00021  *                                                                        */
00022 
00023 /**
00024  * An interceptor interface. Interceptors are used in the parsing stage to change
00025  * the syntax tree of a template, e.g. by adding viewhelper nodes.
00026  *
00027  * @license http://www.gnu.org/licenses/lgpl.html GNU Lesser General Public License, version 3 or later
00028  */
00029 interface Tx_Fluid_Core_Parser_InterceptorInterface {
00030 
00031     const INTERCEPT_OPENING_VIEWHELPER = 1;
00032     const INTERCEPT_CLOSING_VIEWHELPER = 2;
00033     const INTERCEPT_TEXT = 3;
00034     const INTERCEPT_OBJECTACCESSOR = 4;
00035 
00036     /**
00037      * The interceptor can process the given node at will and must return a node
00038      * that will be used in place of the given node.
00039      *
00040      * @param Tx_Fluid_Core_Parser_SyntaxTree_NodeInterface $node
00041      * @param integer $interceptorPosition One of the INTERCEPT_* constants for the current interception point
00042      * @return Tx_Fluid_Core_Parser_SyntaxTree_NodeInterface
00043      */
00044     public function process(Tx_Fluid_Core_Parser_SyntaxTree_NodeInterface $node, $interceptorPosition);
00045 
00046     /**
00047      * The interceptor should define at which interception positions it wants to be called.
00048      *
00049      * @return array Array of INTERCEPT_* constants
00050      */
00051     public function getInterceptionPoints();
00052 }
00053 ?>