diff --git a/singletons-base/CHANGES.md b/singletons-base/CHANGES.md index 691111f3..dca071eb 100644 --- a/singletons-base/CHANGES.md +++ b/singletons-base/CHANGES.md @@ -43,6 +43,18 @@ next [????.??.??] The fact that these were kind-polymorphic to begin with was an oversight, as these could not be used when `k` was instantiated to any other kind besides `Type`. +* The kinds in the `PFunctor` instance for `Compose` are less polymorphic than + they were before: + + ```diff + -instance PFunctor (Compose (f :: k -> Type) (g :: Type -> k)) + +instance PFunctor (Compose (f :: Type -> Type) (g :: Type -> Type)) + ``` + + Similarly for the `PFoldable`, `PTraversable`, `PApplicative`, and + `PAlternative` instances for `Compose`. The fact that these instances were so + polymorphic to begin with was an oversight, as these instances could not be + used when `k` was instantiated to any other kind besides `Type`. 3.4 [2024.05.12] ---------------- diff --git a/singletons-base/src/Data/Functor/Compose/Singletons.hs b/singletons-base/src/Data/Functor/Compose/Singletons.hs index 056971fc..37884974 100644 --- a/singletons-base/src/Data/Functor/Compose/Singletons.hs +++ b/singletons-base/src/Data/Functor/Compose/Singletons.hs @@ -78,23 +78,38 @@ $(singletonsOnly [d| deriving instance Eq (f (g a)) => Eq (Compose f g a) deriving instance Ord (f (g a)) => Ord (Compose f g a) - instance (Functor f, Functor g) => Functor (Compose f g) where + -- Note that in the instances below, we explicitly annotate `f` with its kind + -- (Type -> Type), which is not something that is done in the original base + -- library. This is because when singletons-th promotes instance declarations, + -- it omits the instance contexts. As such, the instance declarations (as well + -- as the associated defunctionalization symbols) would be given overly + -- polymorphic kinds due to kind generalization, e.g., + -- + -- instance PFunctor (Compose (f :: k -> Type) (g :: Type -> k)) where ... + -- + -- Annotating `f :: Type -> Type` is a clunky but reliable way of preventing + -- this. See also Note [Using standalone kind signatures not present in the + -- base library] in Control.Monad.Singletons.Internal for a similar situation + -- where class definitions can become overly polymorphic unless given an + -- explicit kind. + + instance (Functor f, Functor g) => Functor (Compose (f :: Type -> Type) g) where fmap f (Compose x) = Compose (fmap (fmap f) x) a <$ (Compose x) = Compose (fmap (a <$) x) - instance (Foldable f, Foldable g) => Foldable (Compose f g) where + instance (Foldable f, Foldable g) => Foldable (Compose (f :: Type -> Type) g) where foldMap f (Compose t) = foldMap (foldMap f) t - instance (Traversable f, Traversable g) => Traversable (Compose f g) where + instance (Traversable f, Traversable g) => Traversable (Compose (f :: Type -> Type) g) where traverse f (Compose t) = Compose <$> traverse (traverse f) t - instance (Applicative f, Applicative g) => Applicative (Compose f g) where + instance (Applicative f, Applicative g) => Applicative (Compose (f :: Type -> Type) g) where pure x = Compose (pure (pure x)) Compose f <*> Compose x = Compose (liftA2 (<*>) f x) liftA2 f (Compose x) (Compose y) = Compose (liftA2 (liftA2 f) x y) - instance (Alternative f, Applicative g) => Alternative (Compose f g) where + instance (Alternative f, Applicative g) => Alternative (Compose (f :: Type -> Type) g) where empty = Compose empty Compose x <|> Compose y = Compose (x <|> y) |])