terra is a shell of the code-gen flow: Parse AST -> Generate codes.
Disclaimer: This is not an officially supported Agora product.
node >=18
Additional setup required for using cxx-parser
Currently, we do not provide an npm package for this repository. You should depend on
terra
from the GitHub repository using yarn berry as the package manager.
echo "nodeLinker: node-modules" >> .yarnrc.yml
yarn set version berry
yarn add <terra repo url>
# yarn add git@github.com:AgoraIO-Extensions/terra.git#head=main&workspace=terra
# yarn add git@github.com:AgoraIO-Extensions/terra.git#head=main&workspace=terra-core
yarn
The terra configuration uses a YAML format. Here's an example:
# List of parser configurations
parsers:
# Configuration for the first parser
- name: 'my-custom-parser' # Name of the parser, optional
package: 'parser-package-name' # Package name where the parser is located
# path: 'relative/path/to/parser' # Or specify the relative path to the parser
args: # Arguments to pass to the parser
option1: 'value1'
option2: 'value2'
# Configuration for the second parser
- name: 'default-parser' # Default export parser, name can be omitted
path: 'relative/path/to/default-parser'
# package: 'another-parser-package' # Or specify the package name
args:
setting1: 'abc'
setting2: 123
# List of renderer configurations
renderers:
# Configuration for the first renderer
- name: 'example-renderer'
package: 'renderer-package-name'
args:
param1: 'foo'
param2: 'bar'
# Configuration for the second renderer
- path: 'path/to/another-renderer'
args:
config1: true
config2: 'xyz'
# List of global args
globalArgs:
type: 'rtc'
import {
ParseResult,
TerraContext,
TerraNode,
} from '@agoraio-extensions/terra-core';
export interface MyTerraNode extends TerraNode {
myProperty1: string;
myProperty2: string;
}
export default function MyParser(
terraContext: TerraContext,
args: any,
parseResult?: ParseResult
): ParseResult | undefined {
let myTerraNode = {
myProperty1: 'myProperty1',
myProperty2: 'myProperty2',
} as MyTerraNode;
let myParserResult = new ParseResult();
myParserResult.nodes = [myTerraNode];
return myParserResult;
}
import { ParseResult, RenderResult } from '@agoraio-extensions/terra-core';
import { MyTerraNode } from './test_parser';
export default function (parseResult: ParseResult): RenderResult[] {
let fileContent = parseResult.nodes
.map((node) => {
let myTerraNode = node as MyTerraNode;
return `${myTerraNode.myProperty1}\n${myTerraNode.myProperty2}`;
})
.join('\n');
return [{ file_name: 'test_renderer.txt', file_content: fileContent }];
}
Add a config file (e.g., `my_terra_config.yaml``) and execute terra:
# my_terra_config.yaml
parsers:
- path: test_parser.ts
renderers:
- path: test_renderer.ts
npm exec terra -- run --config my_terra_config.yaml --output-dir=<YOUR_OUTPUT_PATH>
- https://github.com/AgoraIO-Extensions/iris_web/blob/main/scripts/terra
- https://github.com/AgoraIO-Extensions/Agora-Flutter-SDK/tree/main/tool/terra
The project is under the MIT license.