<?php /** * Simple file system wrapper for twig to process twig files * * @link http://www.yiiframework.com/ * @copyright Copyright (c) 2008 Yii Software LLC * @license http://www.yiiframework.com/license/ */ namespace yii\twig; /** * Twig view file loader class. * * @author dev-mraj <dev.meghraj@gmail.com> */ class TwigSimpleFileLoader implements \Twig_LoaderInterface { /** * @var string Path to directory */ private $_dir; /** * @param string $dir path to directory */ public function __construct($dir) { $this->_dir = $dir; } /** * Compare a file's freshness with previously stored timestamp * * @param string $name file name to check * @param integer $time timestamp to compare with * @return boolean true if file is still fresh and not changes, false otherwise */ public function isFresh($name, $time) { return filemtime($this->getFilePath($name)) <= $time; } /** * Get the source of given file name * * @param string $name file name * @return string contents of given file name */ public function getSource($name) { return file_get_contents($this->getFilePath($name)); } /** * Get unique key that can represent this file uniquely among other files. * @param string $name * @return string */ public function getCacheKey($name) { return $this->getFilePath($name); } /** * internally used to get absolute path of given file name * @param string $name file name * @return string absolute path of file */ protected function getFilePath($name) { return $this->_dir . '/' . $name; } }