* * For the full copyright and license information, please view the LICENSE * file that was distributed with this source code. */ namespace Symfony\Bundle\FrameworkBundle\Templating; use Symfony\Component\Templating\TemplateReference as BaseTemplateReference; /** * Internal representation of a template. * * @author Victor Berchet */ class TemplateReference extends BaseTemplateReference { public function __construct($bundle = null, $controller = null, $name = null, $format = null, $engine = null) { $this->parameters = array( 'bundle' => $bundle, 'controller' => $controller, 'name' => $name, 'format' => $format, 'engine' => $engine, ); } /** * Returns the path to the template * - as a path when the template is not part of a bundle * - as a resource when the template is part of a bundle * * @return string A path to the template or a resource */ public function getPath() { $controller = $this->get('controller'); $path = (empty($controller) ? '' : $controller.'/').$this->get('name').'.'.$this->get('format').'.'.$this->get('engine'); return empty($this->parameters['bundle']) ? 'views/'.$path : '@'.$this->get('bundle').'/Resources/views/'.$path; } /** * {@inheritdoc} */ public function getLogicalName() { $parts = sprintf('%s:%s:', $this->get('bundle'), $this->get('controller')); $elements = sprintf('%s.%s.%s', $this->get('name'), $this->get('format'), $this->get('engine')); return $parts . $elements; } }