mirror of
https://github.com/github/semantic.git
synced 2025-01-07 07:58:12 +03:00
Define a Pretty1 instance for Free.
This commit is contained in:
parent
2b278c1688
commit
68cc44f91b
@ -8,6 +8,7 @@ import qualified Control.Monad.Free as Free
|
|||||||
import qualified Control.Monad.Trans.Free as FreeF
|
import qualified Control.Monad.Trans.Free as FreeF
|
||||||
import Data.Bifunctor
|
import Data.Bifunctor
|
||||||
import Data.Functor.Both as Both
|
import Data.Functor.Both as Both
|
||||||
|
import Data.Functor.Classes.Pretty
|
||||||
import Data.Mergeable
|
import Data.Mergeable
|
||||||
import Data.Record
|
import Data.Record
|
||||||
import Patch
|
import Patch
|
||||||
@ -63,3 +64,8 @@ free (FreeF.Pure a) = Free.Pure a
|
|||||||
runFree :: Free.Free f a -> FreeF.FreeF f a (Free.Free f a)
|
runFree :: Free.Free f a -> FreeF.FreeF f a (Free.Free f a)
|
||||||
runFree (Free.Free f) = FreeF.Free f
|
runFree (Free.Free f) = FreeF.Free f
|
||||||
runFree (Free.Pure a) = FreeF.Pure a
|
runFree (Free.Pure a) = FreeF.Pure a
|
||||||
|
|
||||||
|
|
||||||
|
instance Pretty1 f => Pretty1 (Free.Free f) where
|
||||||
|
liftPretty p pl = go where go (Free.Pure a) = p a
|
||||||
|
go (Free.Free f) = liftPretty go (liftPrettyList p pl) f
|
||||||
|
Loading…
Reference in New Issue
Block a user