diff -r 000000000000 -r 7f95f8617b0b vendor/symfony/src/Symfony/Bridge/Twig/Extension/RoutingExtension.php --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/vendor/symfony/src/Symfony/Bridge/Twig/Extension/RoutingExtension.php Sat Sep 24 15:40:41 2011 +0200 @@ -0,0 +1,62 @@ + + * + * For the full copyright and license information, please view the LICENSE + * file that was distributed with this source code. + */ + +namespace Symfony\Bridge\Twig\Extension; + +use Symfony\Component\Routing\Generator\UrlGeneratorInterface; + +/** + * Provides integration of the Routing component with Twig. + * + * @author Fabien Potencier + */ +class RoutingExtension extends \Twig_Extension +{ + private $generator; + + public function __construct(UrlGeneratorInterface $generator) + { + $this->generator = $generator; + } + + /** + * Returns a list of functions to add to the existing list. + * + * @return array An array of functions + */ + public function getFunctions() + { + return array( + 'url' => new \Twig_Function_Method($this, 'getUrl'), + 'path' => new \Twig_Function_Method($this, 'getPath'), + ); + } + + public function getPath($name, $parameters = array()) + { + return $this->generator->generate($name, $parameters, false); + } + + public function getUrl($name, $parameters = array()) + { + return $this->generator->generate($name, $parameters, true); + } + + /** + * Returns the name of the extension. + * + * @return string The extension name + */ + public function getName() + { + return 'routing'; + } +}