class Text_Template in Zircon Profile 8
Same name and namespace in other branches
- 8.0 vendor/phpunit/php-text-template/src/Template.php \Text_Template
A simple template engine.
@since Class available since Release 1.0.0
Hierarchy
- class \Text_Template
Expanded class hierarchy of Text_Template
1 string reference to 'Text_Template'
- PHPUnit_Framework_TestCase::createGlobalStateSnapshot in vendor/
phpunit/ phpunit/ src/ Framework/ TestCase.php
File
- vendor/
phpunit/ php-text-template/ src/ Template.php, line 16
View source
class Text_Template {
/**
* @var string
*/
protected $template = '';
/**
* @var string
*/
protected $openDelimiter = '{';
/**
* @var string
*/
protected $closeDelimiter = '}';
/**
* @var array
*/
protected $values = array();
/**
* Constructor.
*
* @param string $file
* @throws InvalidArgumentException
*/
public function __construct($file = '', $openDelimiter = '{', $closeDelimiter = '}') {
$this
->setFile($file);
$this->openDelimiter = $openDelimiter;
$this->closeDelimiter = $closeDelimiter;
}
/**
* Sets the template file.
*
* @param string $file
* @throws InvalidArgumentException
*/
public function setFile($file) {
$distFile = $file . '.dist';
if (file_exists($file)) {
$this->template = file_get_contents($file);
}
else {
if (file_exists($distFile)) {
$this->template = file_get_contents($distFile);
}
else {
throw new InvalidArgumentException('Template file could not be loaded.');
}
}
}
/**
* Sets one or more template variables.
*
* @param array $values
* @param bool $merge
*/
public function setVar(array $values, $merge = TRUE) {
if (!$merge || empty($this->values)) {
$this->values = $values;
}
else {
$this->values = array_merge($this->values, $values);
}
}
/**
* Renders the template and returns the result.
*
* @return string
*/
public function render() {
$keys = array();
foreach ($this->values as $key => $value) {
$keys[] = $this->openDelimiter . $key . $this->closeDelimiter;
}
return str_replace($keys, $this->values, $this->template);
}
/**
* Renders the template and writes the result to a file.
*
* @param string $target
*/
public function renderTo($target) {
$fp = @fopen($target, 'wt');
if ($fp) {
fwrite($fp, $this
->render());
fclose($fp);
}
else {
$error = error_get_last();
throw new RuntimeException(sprintf('Could not write to %s: %s', $target, substr($error['message'], strpos($error['message'], ':') + 2)));
}
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
Text_Template:: |
protected | property | ||
Text_Template:: |
protected | property | ||
Text_Template:: |
protected | property | ||
Text_Template:: |
protected | property | ||
Text_Template:: |
public | function | Renders the template and returns the result. | |
Text_Template:: |
public | function | Renders the template and writes the result to a file. | |
Text_Template:: |
public | function | Sets the template file. | |
Text_Template:: |
public | function | Sets one or more template variables. | |
Text_Template:: |
public | function | Constructor. |