summaryrefslogtreecommitdiff
path: root/dhall/src/errors/HandlerOutputTypeMismatch.txt
blob: f359459f256ff9700f4bfce9e0a058a07919a879 (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
Explanation: You can ❰merge❱ the alternatives of a union using a record with one
handler per alternative, like this:


    ┌─────────────────────────────────────────────────────────────────────┐
    │     let union    = < Left = +2 | Right : Bool >                     │
    │ in  let handlers = { Left = Natural/even, Right = λ(x : Bool) → x } │
    │ in  merge handlers union : Bool                                     │
    └─────────────────────────────────────────────────────────────────────┘


... as long as the output type of each handler function matches the declared type
of the result:


    ┌───────────────────────────────────────────────────────────┐
    │ handlers : { Left : Natural → Bool, Right : Bool → Bool } │
    └───────────────────────────────────────────────────────────┘
                                    ⇧                    ⇧
                                    These output types ...

                             ... must match the declared type of the ❰merge❱
                             ⇩
    ┌─────────────────────────────┐
    │ merge handlers union : Bool │
    └─────────────────────────────┘


For example, the following expression is $_NOT valid:


    ┌──────────────────────────────────────────────────────────────────────┐
    │     let union    = < Left = +2 | Right : Bool >                     │
    │ in  let handlers = { Left = Natural/even, Right = λ(x : Bool) → x } │
    │ in  merge handlers union : Text                                      │
    └──────────────────────────────────────────────────────────────────────┘
                                 ⇧
                                 Invalid: Doesn't match output of either handler


Your handler for the following alternative:

↳ $txt0

... needs to return an output value of type:

↳ $txt1

... but actually returns an output value of a different type:

↳ $txt2