136 lines
2.9 KiB
PHP
136 lines
2.9 KiB
PHP
|
<?php
|
||
|
/*
|
||
|
* This file is part of the Text_Template package.
|
||
|
*
|
||
|
* (c) Sebastian Bergmann <sebastian@phpunit.de>
|
||
|
*
|
||
|
* For the full copyright and license information, please view the LICENSE
|
||
|
* file that was distributed with this source code.
|
||
|
*/
|
||
|
|
||
|
/**
|
||
|
* A simple template engine.
|
||
|
*
|
||
|
* @since Class available since Release 1.0.0
|
||
|
*/
|
||
|
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
|
||
|
)
|
||
|
)
|
||
|
);
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
|