10.8. Type macro and template structure support
The TYPEMACRO_BOOST module provides infrastructure for defining type macros — custom compile-time type transformations. Type macros allow introducing new type syntax that expands into standard daslang types during compilation.
All functions and symbols are in “typemacro_boost” module, use require to get access to it.
require daslib/typemacro_boost
10.8.1. Structures
- TypeMacroTemplateArgument
Holds a type macro template argument with its name and inferred type.
- Fields:
name : string - Name of the template argument.
argument_type : TypeDeclPtr - Declared argument type from the template signature.
inferred_type : TypeDeclPtr - Inferred concrete type after template instantiation.
10.8.2. Function annotations
- typemacro_function
This macro converts function into a type macro.
- typemacro_template_function
This one converts function into a type macro that uses template arguments. For example [typemacro_template(TFlatHashTable)] def makeFlatHashTable ( macroArgument, passArgument : TypeDeclPtr; KeyType, ValueType : TypeDeclPtr; hashFunctionName : string) : TypeDeclPtr { … } We generate the body that handles template argument inference and instantiation.
10.8.3. Structure macros
- typemacro_template
Structure annotation that marks a struct as a type macro template instance.
- typemacro_documentation
Structure annotation that stores type macro documentation metadata.
- template_structure
This macro creates typemacro function and associates it with the structure. It also creates the typemacro_template_function to associate with it. For example:
[template_structure(KeyType,ValueType)] struct template TFlatHashTable { ... }
creates:
1) [typemacro_function] def TFlatHashTable (macroArgument, passArgument : TypeDeclPtr; KeyType, ValueType : TypeDeclPtr) : TypeDeclPtr {
return <- make`template`TFlatHashTable(macroArgument, passArgument, KeyType, ValueType)
}
2) [typemacro_template_function(TFlatHashTable)] def make`template`TFlatHashTable (macroArgument, passArgument : TypeDeclPtr; KeyType, ValueType : TypeDeclPtr) : TypeDeclPtr {
return <- default<TypeDeclPtr>
}
10.8.4. Enum helpers
- int64_to_enum(_enu: auto(ET); value: int64): ET
Converts an int64 value to the specified enum type via reinterpret cast.
- Arguments:
_enu : auto(ET)
value : int64
10.8.5. Template structure instantiation
- is_typemacro_template_instance(passArgument: TypeDeclPtr; templateType: TypeDeclPtr; extra: array<tuple<string;string>> = array<tuple<string;string>>()): bool
template instance is determined by having parent == template.parent
- Arguments:
passArgument : TypeDeclPtr
templateType : TypeDeclPtr
extra : array<tuple<string;string>>
- make_typemacro_template_instance(instance_type: Structure?; template_type: Structure?; ex: array<tuple<string;string>> = array<tuple<string;string>>())
Annotates a structure as a typemacro template instance of the given template type.
- template_structure_name(base: Structure?; arguments: array<TypeMacroTemplateArgument>; extra: array<tuple<string;string>> = array<tuple<string;string>>()): string
Builds a mangled template structure name from its base name and argument types.
- Arguments:
base : Structure?
arguments : array< TypeMacroTemplateArgument>
extra : array<tuple<string;string>>
10.8.6. Type inference helpers
- add_structure_aliases(structType: Structure?; args: array<TypeMacroTemplateArgument>)
Adds all template argument type aliases to a structure.
- Arguments:
structType : Structure?
args : array< TypeMacroTemplateArgument>
- infer_struct_aliases(structType: Structure?; args: array<TypeMacroTemplateArgument>): bool
Infers structure alias types for all template arguments from a structure definition.
- Arguments:
structType : Structure?
args : array< TypeMacroTemplateArgument>
- infer_template_types(passArgument: TypeDeclPtr; args: array<TypeMacroTemplateArgument>): TypeDeclPtr
Infers and validates template argument types against a pass argument, returning the resolved type.
- Arguments:
passArgument : TypeDeclPtr
args : array< TypeMacroTemplateArgument>
- verify_arguments(args: array<TypeMacroTemplateArgument>): bool
Verifies that all template arguments have been fully inferred (no remaining auto or alias types).
- Arguments:
args : array< TypeMacroTemplateArgument>
10.8.7. String constant access
- get_string_const(expr: ExpressionPtr): string
Extracts a string constant value or function address name from an expression.
- Arguments:
expr : ExpressionPtr
10.8.8. Work tracking
- is_custom_work_done(structType: Structure?): bool
Returns true if custom work has already been performed on the template structure.
- Arguments:
structType : Structure?
- mark_custom_work_done(structType: Structure?)
Marks the template structure’s custom work as complete in its annotation.
- Arguments:
structType : Structure?
10.8.9. Type macro arguments
10.8.9.1. typemacro_argument
- typemacro_argument(dimExpr: auto; index: int; constType: ExprConstString; defaultValue: auto(ValueT)): ValueT
Extracts a string constant or function address argument at the given index from a type macro’s dimension expressions.
- Arguments:
dimExpr : auto
index : int
constType : ExprConstString
defaultValue : auto(ValueT)
- typemacro_argument(dimExpr: auto; index: int; constType: auto(ExprConstType); defaultValue: auto(ValueT)): ValueT