diff options
author | Marvin Borner | 2023-03-04 23:00:12 +0100 |
---|---|---|
committer | Marvin Borner | 2023-03-04 23:03:59 +0100 |
commit | 9eaa24413f8e20a759d2c19d1e225b2b7a37a3d0 (patch) | |
tree | bd25c040e87a042a2e29477b0b26201e893f2d88 /std/Box.bruijn | |
parent | 9f3ebcf7be3074e85ba0009440493316ae115a11 (diff) |
Added box functions
Very helpful for some data structures
Diffstat (limited to 'std/Box.bruijn')
-rw-r--r-- | std/Box.bruijn | 41 |
1 files changed, 41 insertions, 0 deletions
diff --git a/std/Box.bruijn b/std/Box.bruijn new file mode 100644 index 0000000..3e3cbfa --- /dev/null +++ b/std/Box.bruijn @@ -0,0 +1,41 @@ +# MIT License, Copyright (c) 2023 Marvin Borner +# a box can store a single item very efficiently +# similar structure to std/Option + +:import std/Logic . +:import std/Combinator . + +# a empty box +empty true ⧗ (Box a) + +# returns true if the box is empty +empty? [0 true [false]] ⧗ (Box a) → Boolean + +:test (empty? empty) (true) + +# builds a box out of a value +box [[[0 2]]] ⧗ a → (Box a) + +# returns true if the box is set +set? [0 false [true]] ⧗ (Box a) → Boolean + +:test (set? (box [0])) (true) +:test (set? empty) (false) + +# sets the value of a empty box, ignores argument if already set +store! [[empty? 1 (box 0) 1]] ⧗ (Box a) → a → (Box a) + +:test (store! (box [[0]]) [[1]]) (box [[0]]) +:test (store! empty [[1]]) (box [[1]]) + +# sets/overrides the value of a box +set! [[(box 0)]] ⧗ (Box a) → a → (Box a) + +:test (set! (box [[0]]) [[1]]) (box [[1]]) +:test (set! empty [[1]]) (box [[1]]) + +# extracts value from a box or returns first argument if none +get [[0 1 i]] ⧗ a → (Box b) → c + +:test (get [[0]] (box [[1]])) ([[1]]) +:test (get [[0]] empty) ([[0]]) |