Custom generator
This generator is simple, it's a callback that enable you to write any file or do any operation in the code generation process. This preset is available for all languages.
Imports
The dependencies you have access to is any native node
dependency and all dependencies listed in The Codegen Project. Here is an example:
import { JavaFileGenerator } from "@asyncapi/modelina";
export default {
...
generators: [
{
preset: 'custom',
...
renderFunction: ({generator, inputType, asyncapiDocument, dependencyOutputs})
{
const modelinaGenerator = new JavaFileGenerator({});
modelinaGenerator.generateCompleteModels(...)
}
}
]
};
Dependencies
In each generator (don't manually use it unless you use preset: custom
, you can add dependencies
property, which takes an array of id
's that the rendering engine ensures are rendered before the dependant one.
Each generator has a specific output (except custom
which is dynamic and under your control), they are documented under each ./generators. These outputs can be accessed under dependencyOutputs
.
There are two rules though;
- You are not allowed to have circular dependencies, i.e. two generators both depending on each other.
- You are not allowed to have self-dependant generators
How does it work?
For example, take two generators, you can chain them together and use one's output in the other, as for example below, to have the console print out Hello World!
.
export default {
...
generators: [
{
preset: 'custom',
renderFunction: ({dependencyOutputs}) => {
console.log(dependencyOutputs['bar'])
},
dependencies: ['bar']
},
{
preset: 'custom',
id: 'bar',
renderFunction: () => {
return 'Hello World!'
}
}
]
};
Arguments
In the renderFunction
you have access to a bunch of arguments to help you create the callback;
generator
- is the generator configuration, where you have access to theoptions
and all other information.inputType
- is the rootinputType
for the input documentasyncapiDocument
- is the parsed AsyncAPI document input (according to the AsyncAPI parser), undefined if theinputType
is notasyncapi
dependencyOutputs
- if you have defined anydependencies
, this is where you can access the output. Checkout the dependency documentation for more information.