aboutsummaryrefslogtreecommitdiff
path: root/src/Utils.elm
blob: 83e025b41b7973fdde59d3071352c546f02d1dd2 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
module Utils exposing (..)

import Array as A exposing (..)
import Base exposing (Word, WordStatus(..))
import Time exposing (Posix, posixToMillis)


isNothing : Maybe a -> Bool
isNothing p =
    case p of
        Nothing ->
            True

        Just a ->
            False


isJust : Maybe a -> Bool
isJust p =
    not (isNothing p)


flip : (a -> b -> c) -> (b -> a -> c)
flip f =
    \x y -> f y x


diffDuration : Posix -> Posix -> Float
diffDuration t1 t2 =
    let
        m1 =
            posixToMillis t1

        m2 =
            posixToMillis t2
    in
    toFloat (m2 - m1) / 1000


wordCountWith : Array Word -> (WordStatus -> Bool) -> Int
wordCountWith words predicate =
    words |> A.map .status |> A.filter predicate |> A.length


triple : a -> b -> c -> ( a, b, c )
triple a b c =
    ( a, b, c )


listIdx : List a -> Int -> Maybe a
listIdx ls idx =
    List.head (List.drop idx ls)