Skip to content

Commit

Permalink
feature #4504 Add a way to stream template rendering (fabpot)
Browse files Browse the repository at this point in the history
This PR was merged into the 3.x branch.

Discussion
----------

Add a way to stream template rendering

Even if we're using `yield` internally, there is no easy way to stream template rendering. This new method can be used like this to HTTP stream a template with Symfony:

```php
use Symfony\Component\HttpFoundation\StreamedResponse;
use Twig\Environment;

$twig = new Environment(/* ... */);

$response = new StreamedResponse($twig->load('index')->stream([]));
$response->send();
```

Commits
-------

1915ee2 Add a way to stream template rendering
  • Loading branch information
fabpot committed Dec 18, 2024
2 parents d78cb00 + 1915ee2 commit f99eab8
Show file tree
Hide file tree
Showing 3 changed files with 42 additions and 6 deletions.
2 changes: 1 addition & 1 deletion CHANGELOG
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
# 3.18.0 (2024-XX-XX)

* n/a
* Add a way to stream template rendering (`TemplateWrapper::stream()` and `TemplateWrapper::streamBlock()` )

# 3.17.1 (2024-12-12)

Expand Down
30 changes: 25 additions & 5 deletions doc/api.rst
Original file line number Diff line number Diff line change
Expand Up @@ -40,23 +40,26 @@ templates from a database or other resources.
the evaluated templates. For such a need, you can use any available PHP
cache library.

Rendering Templates
-------------------
Loading Templates
-----------------

To load a template from a Twig environment, call the ``load()`` method which
To load a template, call the ``load()`` method on a Twig environment which
returns a ``\Twig\TemplateWrapper`` instance::

$template = $twig->load('index.html.twig');

To render the template with some variables, call the ``render()`` method::
Rendering Templates
-------------------

To render a template with some variables, call the ``render()`` method::

echo $template->render(['the' => 'variables', 'go' => 'here']);

.. note::

The ``display()`` method is a shortcut to output the rendered template.

You can also load and render the template in one fell swoop::
You can also load and render the template directly via the Environment::

echo $twig->render('index.html.twig', ['the' => 'variables', 'go' => 'here']);

Expand All @@ -65,6 +68,23 @@ If a template defines blocks, they can be rendered individually via the

echo $template->renderBlock('block_name', ['the' => 'variables', 'go' => 'here']);

Streaming Templates
-------------------

.. versionadded:: 3.18.0

To stream a template, call the ``stream()`` method`::

$template->stream(['the' => 'variables', 'go' => 'here']);

To stream a specific template block, call the ``streamBlock()`` method::

$template->streamBlock('block_name', ['the' => 'variables', 'go' => 'here']);

.. note::

The ``stream()`` and ``streamBlock()`` methods return an iterable.

.. _environment_options:

Environment Options
Expand Down
16 changes: 16 additions & 0 deletions src/TemplateWrapper.php
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,22 @@ public function __construct(
) {
}

/**
* @return iterable<scalar|\Stringable|null>
*/
public function stream(array $context = []): iterable
{
yield from $this->template->yield($context);
}

/**
* @return iterable<scalar|\Stringable|null>
*/
public function streamBlock(string $name, array $context = []): iterable
{
yield from $this->template->yieldBlock($name, $context);
}

public function render(array $context = []): string
{
return $this->template->render($context);
Expand Down

0 comments on commit f99eab8

Please sign in to comment.