Cast
Cast is a template that should be generated. It consists of the following sections:
to
- path where the cast should be generatedfrom
- source of the castvariables
- variables that can be used in the cast
Additionally, cast can have the following sections:
if
,unless
- condition(s) that should (or not) be met to render the casteach
- collection that should be used to render the cast multiple times
And other sections that will be later mentioned in Conditional Rendering and Collection Casts sections.
Cast destination (to)
Destination is a path where the cast should be generated. It must be relative to the root
property. The destination may be templated using the Variables section at root level and from the cast context.
Cast source (from)
Source defined the content of the cast that should be rendered. In v1, source can just be defined by templated strings. Now, sources can also be defined by referencing to other magic manifest. See more in Sources page.
Cast variables
Variables are used to provide data for cast generation. They can be used in the to
and from
fields. Variables are defined as a list of variable objects. The value can be either a string or a list of strings. Further information about variables can be found in the Variables section.
Example
version: 1
name: My Project
root: ./generated
casts:
hello-world:
to: ./hello-world
from: |
Hello {{ .project_name }}!
variables:
- name: project_name
value: My Project
Example using magic sources
---
# file: manifest.yaml
version: 1
name: My Project
root: .
casts:
hello-world:
to: ./hello-world
from:
magic: ./hello-world.yaml
variables:
- name: project_name
value: My Project
# file: hello-world.yaml
version: 1
name: Hello World
root: .
casts:
hello-world:
to: ./hello-world
from: |
Hello {{ .project_name }}!
variables:
- name: project_name
value: My Project