{-# LANGUAGE DeriveGeneric #-} {-# LANGUAGE TemplateHaskell #-} {-# LANGUAGE FlexibleInstances #-} {-# LANGUAGE MultiParamTypeClasses #-} {-# LANGUAGE DeriveGeneric #-} module Definitions where import GHC.Generics (Generic) -- We define the data types and generate the TH in a separate module -- because we want to ensure that no external names are required to be -- imported. import Data.Profunctor.Product (ProductProfunctor, SumProfunctor) import Data.Profunctor.Product.Adaptor (Unzippable) import Data.Profunctor.Product.Default (Default) import Data.Profunctor.Product.TH (makeAdaptorAndInstance, makeAdaptorAndInstance') data Data2 a b = Data2 a b deriving Generic data Data3 a b c = Data3 a b c deriving Generic data Record2 a b = Record2 { a2 :: a, b2 :: b } deriving Generic data Record3 a b c = Record3 { a3 :: a, b3 :: b, c3 :: c } deriving Generic data RecordDefaultName x y = RecordDefaultName { x :: x, y :: y } deriving Generic data DataGeneric a b c = DataGeneric a b c deriving Generic data RecordGeneric a b c = RecordGeneric { a4 :: a, b4 :: b, c4 :: c } deriving Generic data SumGeneric a b = SumL a | SumR b deriving Generic data ProductAndSumGeneric a b c = PSumL a | PSumR b c deriving Generic $(makeAdaptorAndInstance "pData2" ''Data2) $(makeAdaptorAndInstance "pData3" ''Data3) $(makeAdaptorAndInstance "pRecord2" ''Record2) $(makeAdaptorAndInstance "pRecord3" ''Record3) $(makeAdaptorAndInstance' ''RecordDefaultName) instance Unzippable Data2 instance Unzippable Data3 instance (ProductProfunctor p, Default p a a', Default p b b', Default p c c') => Default p (DataGeneric a b c) (DataGeneric a' b' c') instance (ProductProfunctor p, Default p a a', Default p b b', Default p c c') => Default p (RecordGeneric a b c) (RecordGeneric a' b' c') instance (SumProfunctor p, Default p a a', Default p b b') => Default p (SumGeneric a b) (SumGeneric a' b') instance (ProductProfunctor p, SumProfunctor p, Default p a a', Default p b b', Default p c c') => Default p (ProductAndSumGeneric a b c) (ProductAndSumGeneric a' b' c')