Template Syntax

Here is an overview of the general syntax of a template.

You reference variables in the following syntax:

{{color0}}

For applying a filter you use the pipe character (|) like this:

{{background | strip}}

And if the filter requires an argument:

{{background | lighten(0.3)}}

Remember that filters require a valid type to apply to in these examples we are using colors, which can even be defined literally:

{{ "#4ff4ff" | lighten(0.3)}}

For both, being applied to or as an argument of a filter:

{{ color2 | blend("4ff4ff")}}

You can chain multiple filters, this is why the return type of the filter is important.

{# This will get a color without the initial '#',
   0.5 lighter than before and it's complementary variant. }
{{ color2 | strip | lighten(0.5) | complementary}}

If you need to write a literal {{, that doesn't references any variable, you can write literals inside the delimiters:

{{ "{{" }} {{ "}}" }}

You can also use control flow expressions with {% %} delimiters:

{% if backend == "wal" %}
I am using the '{{backend}}' backend, getting a pywal like scheme.
{% elif backend == "fastresize" %}
This backend is called "{{palette}}" and, uses SIMD optimizations and is so fast!
{% else %}
I don't care about any other backends. Be happy!
{% endif %}

Or inline them:

{{ "I'm using the kmeans algo!" if backend == "kmeans" else "Some backend is in use" }}

Since mostly everything can be represented as a string (we've seen how colors are represented), indexing results very useful! The syntax for indexing is basically the Python one.

{# I'll hardcode a color based on the palette being used. #}
{% if palette[:4] == "dark" %}
somevariable = "#eeffbb"
{% else %}
somevariable = "#aabbee"
{% endif %}

And yes, you can comment inside your template, the comments won't be rendered in the final target file:

{# This won't be visible! #}

There are more control flow instructions, like the for loop:

{# This will generate color0 = .. to color18,
since `colors` contains background, foreground and cursor variables #}
{% for c in colors %}
color{{- loop.index }} = {{c-}}
{% endfor %}

You can add a minus sign (-) at the start or the end of the delimiters to supress vertical spacing (White space control with the minus sign -)

The syntax comes from the library being used, which is minijinja, a subset of the template engine 'Jinja2'.

You can read more at: Jinja2 official syntax and contrast features with the supported syntax at Compatibility of minijinja