Configuration
The T compiler can have various variables tweaked to control the bahviour of the compiler
types
Anything regarding the type system (this includes the type checker and the meta processor).
types:max_width
- This entry holds an integrak value
- This sets the maximum bit-width of a machine (in bytes)
- This can either be
1
,2
,4
or8
- It affects how alises such as
size_t
andssize_t
behave in terms of what the resolve to
dgen
These options configure the C code emitter.
dgen:pretty_code
- This entry holds a boolean value
- If
true
then the emitted code will be prettified, meaning it will be correctly indented. Iffalse
then no such prettifying will occur. - Default:
true
dgen:mapper
- This entry holds a string value
- This controls how symbol names within T are translated
- The two available options are:
"hashmapper"
- the hash of the T symbol name is the result"lebanese"
- all periods (.
) within T symbols are replaced by underscores (_
)- Default:
"hashmapper"
dgen:emit_entrypoint_test
- This entry holds a boolean value
- If
true
then instrumentation code will be added to the final output source code prior to compilation - Default:
true
dgen:preinline_args
- This entry holds a boolean value
- If
true
then the arguments (expressions) given to a function call will be placed in adhoc variables declared in order of appearance - These variables will be passed to the function call then
- Default:
false
(TODO: change)
dgen:compiler
- This entry holds a string value
- This is the path to the compiler executable that should be used to compile the generated C code
- Default:
clang
emit
This controls aspects of the CodeEmitter
API, meaning irrespective of
which emitter (such as dgen
) is used.
TODO: Move dgen_emit_entrypoint_test
and dgen:pretty_code
here.