yaml
Reads structured data from a YAML file.
The file must contain a valid YAML object or array. YAML mappings will be
converted into Typst dictionaries, and YAML sequences will be converted into
Typst arrays. Strings and booleans will be converted into the Typst
equivalents, null-values (null, ~ or empty ``) will be converted into
none, and numbers will be converted to floats or integers depending on
whether they are whole numbers. Custom YAML tags are ignored, though the
loaded value will still be present.
Be aware that integers larger than 263-1 will be converted to floating point numbers, which may give an approximative value.
The YAML files in the example contain objects with authors as keys, each with a sequence of their own submapping with the keys "title" and "published"
Example
#let bookshelf(contents) = {
  for (author, works) in contents {
    author
    for work in works [
      - #work.title (#work.published)
    ]
  }
}
#bookshelf(
  yaml("scifi-authors.yaml")
)

ParameterParameterParameters are input values for functions. Specify them in parentheses after the function name.
yaml()->anyDefinitionsDefinitionsThese functions and types can have related definitions. To access a definition, specify the name of the function or type, followed by the definition name separated by a period.
decode
decodeReads structured data from a YAML string/bytes.
yaml.decode()->anyencode
encodeEncode structured data into a YAML string.
yaml.encode(any)->valueanyRequiredRequiredRequired parameters must be specified when calling the function.PositionalPositionalPositional parameters can be set by specifying them in order, omitting the parameter name.
valueValue to be encoded.