The Engine

The Engine is the Boiler's central object and usually the only one you have to manually instatiate. It is used to locate and load templates from the file system.

Throughout this page we assume the following directory structure:

path
`-- to
    |-- templates
    `-- additional

Creating the Engine instance

To create an Engine instance, you simply pass one or more paths to directories where your templates are located. Additionally, you can optionally set default values that are available for all your templates, or you can globally disable the autoescaping feature.

Using a single template directory

The only required parameter of the constructor is the path to a directory where your templates reside:

$engine = new \FiveOrbs\Boiler\Engine('/path/to/templates');

If the directory does not exists, Boiler throws a \FiveOrbs\Boiler\Exception\DirectoryNotFound exception.

Using multiple directories

If you have multiple directories, pass them in an array:

$engine = new \FiveOrbs\Boiler\Engine(['/path/to/templates', '/path/to/additional']);

Note: The directories are searched in order.

Using the example above: If a template cannot be located in /path/to/additional, Boiler tries to find it in /path/to/additional and so on.

Using namespaces

You can use namespaces to later be able to address a specific directory. Pass the list of directories as associative array where the keys serve as namespaces:

$engine = new \FiveOrbs\Boiler\Engine([
    'first' => '/path/to/templates', 
    'second' => '/path/to/additional'
]);

Check Rendering Templates to see it in action.

Adding default values

You can assign default values which are available in all templates:

$engine = new \FiveOrbs\Boiler\Engine('/path/to/dir', ['value' => 'default value']);

Turning off autoescaping

If you don't want to use the autoescaping feature, e. g. to improve the performance of your application, you can turn it off globally:

$engine = new \FiveOrbs\Boiler\Engine('/path/to/dir', [], false);

// better:
$engine = new \FiveOrbs\Boiler\Engine('/path/to/dir', autoescape: false);

Rendering Templates

You simplic call the render method and pass the name/path of the template and optionally an array of values (the context) which will be available as variables in the template.

$engine->render('template');

// with context
$engine->render('template', ['value1' => 1, 'value2' => 2]);

See Rendering Templates for more information.

Adding custom template methods

Custom methods can be accessed in templates using $this (See Rendering Templates). To a add a method you pass aClosure or anonymous function to registerMethod:

$engine->registerMethod('upper', function (string $value): string {
    return strtoupper($value);
});

Other useful Engine methods

Check if a template exists

To check if a template exists before rendering it, use the method exists:

if ($engine->exists('template')) {
    $engine->render('template');
}

Get the file system path of a template

$filePath = $engine->getFile('template');

Get a template instance without rendering it

$template = $engine->template('template');

assert($template instanceof \FiveOrbs\Boiler\Template);