{-# LANGUAGE DataKinds #-}
{-# LANGUAGE Trustworthy #-}
{-# LANGUAGE TypeFamilies #-}
{-# OPTIONS_GHC -Wno-orphans #-}
{-# OPTIONS_HADDOCK show-extensions #-}
module Data.Tuple.Homotuple.Only () where
import Data.Tuple.Homotuple (Homotuple, errorLengthMismatch)
import Data.Tuple.Only (Only (Only))
import GHC.Exts (IsList (Item, fromList, toList))
type instance Homotuple 1 a = Only a
instance IsList (Only a) where
type Item (Only a) = a
fromList :: [Item (Only a)] -> Only a
fromList [Item (Only a)
a] = a -> Only a
forall a. a -> Only a
Only a
Item (Only a)
a
fromList [Item (Only a)]
_ = Only a
forall a. HasCallStack => a
errorLengthMismatch
toList :: Only a -> [Item (Only a)]
toList (Only a
a) = [a
Item (Only a)
a]