首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >用于GADT的makeLenses (Haskell)

用于GADT的makeLenses (Haskell)
EN

Stack Overflow用户
提问于 2015-01-26 13:59:16
回答 1查看 610关注 0票数 8

是否有用于GADT的等价物makeLenses?如果我有一个简单的GADT,比如:

代码语言:javascript
复制
data D a b where
  D :: (Ord a, Ord b) => !a -> !b -> D a b

有没有一种方法可以通过传入构造函数和字段名列表来自动生成镜头?

EN

回答 1

Stack Overflow用户

发布于 2015-01-26 14:53:57

我不认为它可以自动完成,但在这种情况下,手动编写一些镜头并不是那么困难:

代码语言:javascript
复制
{-# LANGUAGE GADTs #-}

import Control.Lens

data D a b where
  D :: (Ord a, Ord b) => !a -> !b -> D a b

field1 :: Lens' (D a b) a
field1 f (D x y) = fmap (\x' -> D x' y) (f x)

field2 :: Lens' (D a b) b
field2 f (D x y) = fmap (\y' -> D x y') (f y)

{- If you want type-changing lenses, you can also use these signatures.
 - Note that then the target type Ord constraint has to escape.

field1 :: (Ord a2) => Lens (D a1 b) (D a2 b) a1 a2
field2 :: (Ord b2) => Lens (D a b1) (D a b2) b1 b2
 -}

似乎有一个有点相关的GitHub issue,其中克梅特声称他们不能为存在量化的领域创造透镜。

票数 7
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/28145369

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档