summaryrefslogtreecommitdiff
path: root/testsuite/tests/gadt/Gadt17_help.hs
blob: 5161fdcdb7399f5c0b27dede34dff89bfa3322dd (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
{-# LANGUAGE GADTs #-}
{-# OPTIONS_GHC -O -fno-warn-redundant-constraints #-}

module Gadt17_help (
      TernOp (..), applyTernOp
    ) where

data TypeWitness a   where
    TWInt    ::         TypeWitness Int
    TWBool   ::         TypeWitness Bool
    TWFloat  ::         TypeWitness Float
    TWDouble ::         TypeWitness Double

instance (Eq a) => Eq (TypeWitness a) where
  (==) TWInt     TWInt     = True
  (==) TWBool    TWBool    = True
  (==) TWFloat   TWFloat   = True
  (==) TWDouble  TWDouble  = True

data TernOp a b c d where
  OpIf       ::                   TypeWitness a                    ->    TernOp Bool   a      a      a
  OpTernFunc ::  TypeWitness a -> TypeWitness b -> TypeWitness c
                            -> TypeWitness d -> (a -> b -> c -> d) ->    TernOp a      b      c      d

instance Show (TernOp a b c d) where
  show (OpIf       {})  = "OpIf"
  show (OpTernFunc {})  = "OpTernFunc <function>"


applyTernOp :: TernOp a b c d -> a -> b -> c -> d
applyTernOp (OpIf       {})         cond x y = if (cond) then x else y
applyTernOp (OpTernFunc _ _ _ _ f)  x    y z = f x y z