首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Haskell:用于Fix类型的派生显示

Haskell:用于Fix类型的派生显示
EN

Stack Overflow用户
提问于 2017-03-21 18:36:45
回答 1查看 633关注 0票数 6

我正在尝试使用recursion-schemes实现递归数据类型。我想把它打印出来。

代码语言:javascript
复制
import Data.Functor.Foldable

data T1F a = Foo deriving Show
type T1 = Fix T1F
data T2 = Bar T1 deriving Show -- error here

错误消息:

代码语言:javascript
复制
No instance for (Data.Functor.Classes.Show1 T1F)
  arising from the first field of ‘Bar’ (type ‘T1’)
Possible fix:
  use a standalone 'deriving instance' declaration,
    so you can specify the instance context yourself
When deriving the instance for (Show T2)

如何使T1派生Show

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2017-03-21 19:50:02

使用包deriving-compat

代码语言:javascript
复制
{-# LANGUAGE TemplateHaskell #-}
import Data.Functor.Foldable
import Text.Show.Deriving

data T1F a = Foo deriving Show
$(deriveShow1 ''T1F)
type T1 = Fix T1F
data T2 = Bar T1 deriving Show
票数 3
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/42935549

复制
相关文章

相似问题

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