2024-10-22 10:53:10 +00:00
|
|
|
# interoperability
|
|
|
|
api needs to facilitate easy interoperability with other languages and tools,
|
|
|
|
for that certain considerations are taken:
|
|
|
|
|
|
|
|
* number of public api calls is kept at the minimum
|
2024-10-22 11:45:30 +00:00
|
|
|
* procedure parameters can only use basic types, no aggregates, with exception of Vec/Matrix types and alike,
|
2024-10-22 10:53:10 +00:00
|
|
|
with no expectation on new additions (see [/include/twn_types.h](/include/twn_types.h))
|
|
|
|
* optionals can be expressed via pointer passage of value primitives, with NULL expressive default, but they should be immutable
|
2024-10-22 11:45:30 +00:00
|
|
|
* opaque typed parameters are passed around as pointers
|
2024-10-22 10:53:10 +00:00
|
|
|
* when mutation on input is done, - it shouldn't be achieved from a mutable pointer, but return value
|
2024-10-22 11:45:30 +00:00
|
|
|
* return value could be a simple aggregate that is translatable to value-only dictionary
|
2024-10-22 10:53:10 +00:00
|
|
|
* module prefix is used for namespacing, actual symbols come after the prefix (`module_symbol`)
|
|
|
|
* symbols should not contain letters at the start nor after the namespace prefix
|
2024-10-22 11:45:30 +00:00
|
|
|
* floats are preferred over integers
|
2024-10-22 10:53:10 +00:00
|
|
|
* [/include/twn_api.json](/include/twn_api.json) file is hand-kept with a schema to aid automatic binding generation and other tooling
|