diff options
| author | 2026-02-23 20:36:05 +0100 | |
|---|---|---|
| committer | 2026-02-23 20:36:05 +0100 | |
| commit | 052144cabb126efe925a96f8a0597a0f2005d206 (patch) | |
| tree | 4fd87244b9eef018b30e90fdff24c5b1a145a85e /test/external/metalang99/examples/binary_tree.c | |
| parent | 4e9020dfb847d80475415f9f5914efaa50238767 (diff) | |
add metalang99 testsuite (preprocessor stress testing)
Diffstat (limited to 'test/external/metalang99/examples/binary_tree.c')
| -rw-r--r-- | test/external/metalang99/examples/binary_tree.c | 25 |
1 files changed, 25 insertions, 0 deletions
diff --git a/test/external/metalang99/examples/binary_tree.c b/test/external/metalang99/examples/binary_tree.c new file mode 100644 index 0000000..8cd9177 --- /dev/null +++ b/test/external/metalang99/examples/binary_tree.c @@ -0,0 +1,25 @@ +// Sums all nodes of a binary tree, recursively. + +#include <metalang99.h> + +#define leaf(x) ML99_choice(v(leaf), x) +#define node(lhs, data, rhs) ML99_choice(v(node), lhs, data, rhs) + +#define sumTree(tree) ML99_match(tree, v(sumTree_)) +#define sumTree_leaf_IMPL(x) v(x) +#define sumTree_node_IMPL(lhs, data, rhs) ML99_add3(sumTree(v(lhs)), v(data), sumTree(v(rhs))) + +/* + * 4 + * / \ + * / \ + * / \ + * 2 6 + * / \ / \ + * 1 3 5 7 + */ +#define TREE node(node(leaf(v(1)), v(2), leaf(v(3))), v(4), node(leaf(v(5)), v(6), leaf(v(7)))) + +ML99_ASSERT_EQ(sumTree(TREE), v(28)); + +int main(void) {} |