You are here

Template.php in Zircon Profile 8

File

vendor/phpunit/php-text-template/src/Template.php
View source
<?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)));
    }
  }

}

Classes

Namesort descending Description
Text_Template A simple template engine.