如何从Haskell中的(G)ADT参数获取构造函数作为函数?

时间:2015-02-18 22:18:20

标签: haskell gadt

如何从Haskell中的(G)ADT参数获取构造函数? 有可能做这样的事吗?

data  Ex1 =  C1 Int | C2 Int -- | ..... 
           | C3

fun :: Ex1 -> Ex1
fun C3    = C3
fun (c i) = c $ i^2

我不适合。

fun (C1 i) = C1 $ i^2
fun (C2 i) = C2 $ i^2

1 个答案:

答案 0 :(得分:6)

如果您可以更改Ex1的类型,那么:

{-# LANGUAGE DeriveFunctor #-}

data  Ex1 a =  C1 a | C2 a
            | C3 deriving (Show, Functor)

fun :: Ex1 Int -> Ex1 Int
fun y = fmap (\x -> x^2) y

ghci演示:

λ> fun $ C1 3
C1 9
λ> fun $ C2 3
C2 9
λ> fun C3
C3