What is Jinja / Cookbook
BAML Prompt strings are essentially Minijinja templates, which offer the ability to express logic and data manipulation within strings. Jinja is a very popular and mature templating language amongst Python developers, so Github Copilot or another LLM can already help you write most of the logic you want.
Jinja Cookbook
When in doubt — use the BAML VSCode Playground preview. It will show you the fully rendered prompt, even when it has complex logic.
Basic Syntax
- {% ... %}: Use for executing statements such as for-loops or conditionals.
- {{ ... }}: Use for outputting expressions or variables.
- {# ... #}: Use for comments within the template, which will not be rendered.
Loops / Iterating Over Lists
Here’s how you can iterate over a list of items, accessing each item’s attributes:
Conditional Statements
Use conditional statements to control the flow and output of your templates based on conditions:
Setting Variables
You can define and use variables within your templates to simplify expressions or manage data:
Including other Templates
To promote reusability, you can include other templates within a template. See template strings:
Built-in filters
See jinja docs