import datatypes struct KeyVal { mut: key int val int } fn (a KeyVal) == (b KeyVal) bool { return a.key == b.key } fn (a KeyVal) < (b KeyVal) bool { return a.key < b.key } fn main() { mut bst := datatypes.BSTree<KeyVal>{} bst.insert(KeyVal{ key: 1, val: 12 }) println(bst.in_order_traversal()) bst.insert(KeyVal{ key: 2, val: 34 }) bst.insert(KeyVal{ key: -2, val: 203 }) for elem in bst.in_order_traversal() { println(elem.val) } }