{-# LANGUAGE ExistentialQuantification, RankNTypes #-}
module Data.Exists.Constrained where

import Data.Typeable

-- | Dependent sum
data E c a =  k . (Typeable k, c k) => E { unE :: a k }

map :: ( k . c k => a k -> b k) -> E c a -> E c b
map f (E a) = E (f a)

mapF :: Functor f => ( k . c k => a k -> f (b k)) -> E c a -> f (E c b)
mapF f (E a) = E <$> f a