diff options
Diffstat (limited to 'website/sandbox/learnpianochords/src/Misc.elm')
-rw-r--r-- | website/sandbox/learnpianochords/src/Misc.elm | 47 |
1 files changed, 47 insertions, 0 deletions
diff --git a/website/sandbox/learnpianochords/src/Misc.elm b/website/sandbox/learnpianochords/src/Misc.elm new file mode 100644 index 000000000000..52f957ad528f --- /dev/null +++ b/website/sandbox/learnpianochords/src/Misc.elm @@ -0,0 +1,47 @@ +module Misc exposing (..) + +import Array exposing (Array) + + +comesAfter : a -> List a -> Maybe a +comesAfter x xs = + case xs of + [] -> + Nothing + + _ :: [] -> + Nothing + + y :: z :: rest -> + if y == x then + Just z + + else + comesAfter x (z :: rest) + + +comesBefore : a -> List a -> Maybe a +comesBefore x xs = + case xs of + [] -> + Nothing + + _ :: [] -> + Nothing + + y :: z :: rest -> + if z == x then + Just y + + else + comesBefore x (z :: rest) + + +find : (a -> Bool) -> List a -> Maybe a +find pred xs = + case xs |> List.filter pred of + [] -> + Nothing + + x :: _ -> + Just x |