我不确定我在这里做错了什么:
data Vector2D u = Vector2D {
_x :: u,
_y :: u
} deriving stock (Show, Eq, Functor, Foldable, Traversable)
{-# INLINE addVector2 #-}
addVector2 :: (Additive a) => Vector2D a -> Vector2D a -> Vector2D a
addVector2 (Vector2D { _x = x1, _y = y1 }) (Vector2D { _x = x2, _y = y2 }) =
Vector2D { _x = x1 + x2, _y = y1 + y2 }
instance (Additive a) => Additive (Vector2D a) where
(+) = addVector2
newtype Square a = Square {
unpackSquare :: Vector2D a
} deriving stock (Show, Eq)
到目前为止,一切正常(Additive 在代数包中定义,但非常不言自明)。
但是,现在我想聪明地使用 DerivingVia 和 StandaloneDeriving,我什至无法编译下一行
deriving instance (Additive a) => Additive (Square a) via (Vector2D a)
但这让我
* 预期种类 `k0 -> * -> Constraint', 但是 `Additive (Square a)' 有一种 `Constraint' * 在独立派生实例中 `(Additive a) => Additive (Square a) via (Vector2D a)'
谁能告诉我我做错了什么?我正在运行 GHC 8.6.2