Deriving Via With Standalone Deriving
I'm not really sure what I'm doing wrong here:
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)
So far, so normal (Additive is defined in the algebra package but is pretty self-explanatory).
However, now I want to be clever using DerivingVia and StandaloneDeriving and I can't even get the next line to compile
deriving instance (Additive a) => Additive (Square a) via (Vector2D a)
But that gets me
* Expected kind `k0 -> * -> Constraint',
but `Additive (Square a)' has kind `Constraint'
* In the stand-alone deriving instance for
`(Additive a) => Additive (Square a) via (Vector2D a)'
Can anyone tell me what I'm doing wrong? I'm running GHC 8.6.2
haskell deriving
add a comment |
I'm not really sure what I'm doing wrong here:
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)
So far, so normal (Additive is defined in the algebra package but is pretty self-explanatory).
However, now I want to be clever using DerivingVia and StandaloneDeriving and I can't even get the next line to compile
deriving instance (Additive a) => Additive (Square a) via (Vector2D a)
But that gets me
* Expected kind `k0 -> * -> Constraint',
but `Additive (Square a)' has kind `Constraint'
* In the stand-alone deriving instance for
`(Additive a) => Additive (Square a) via (Vector2D a)'
Can anyone tell me what I'm doing wrong? I'm running GHC 8.6.2
haskell deriving
1
For what it is worth, I prefer your syntax withvia ...
at the end to the one actually accepted by GHC, wherevia
comes earlier.
– chi
Nov 21 '18 at 19:50
add a comment |
I'm not really sure what I'm doing wrong here:
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)
So far, so normal (Additive is defined in the algebra package but is pretty self-explanatory).
However, now I want to be clever using DerivingVia and StandaloneDeriving and I can't even get the next line to compile
deriving instance (Additive a) => Additive (Square a) via (Vector2D a)
But that gets me
* Expected kind `k0 -> * -> Constraint',
but `Additive (Square a)' has kind `Constraint'
* In the stand-alone deriving instance for
`(Additive a) => Additive (Square a) via (Vector2D a)'
Can anyone tell me what I'm doing wrong? I'm running GHC 8.6.2
haskell deriving
I'm not really sure what I'm doing wrong here:
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)
So far, so normal (Additive is defined in the algebra package but is pretty self-explanatory).
However, now I want to be clever using DerivingVia and StandaloneDeriving and I can't even get the next line to compile
deriving instance (Additive a) => Additive (Square a) via (Vector2D a)
But that gets me
* Expected kind `k0 -> * -> Constraint',
but `Additive (Square a)' has kind `Constraint'
* In the stand-alone deriving instance for
`(Additive a) => Additive (Square a) via (Vector2D a)'
Can anyone tell me what I'm doing wrong? I'm running GHC 8.6.2
haskell deriving
haskell deriving
edited Nov 21 '18 at 10:10
leftaroundabout
79.4k3118233
79.4k3118233
asked Nov 20 '18 at 23:21
Julian BirchJulian Birch
1,476923
1,476923
1
For what it is worth, I prefer your syntax withvia ...
at the end to the one actually accepted by GHC, wherevia
comes earlier.
– chi
Nov 21 '18 at 19:50
add a comment |
1
For what it is worth, I prefer your syntax withvia ...
at the end to the one actually accepted by GHC, wherevia
comes earlier.
– chi
Nov 21 '18 at 19:50
1
1
For what it is worth, I prefer your syntax with
via ...
at the end to the one actually accepted by GHC, where via
comes earlier.– chi
Nov 21 '18 at 19:50
For what it is worth, I prefer your syntax with
via ...
at the end to the one actually accepted by GHC, where via
comes earlier.– chi
Nov 21 '18 at 19:50
add a comment |
1 Answer
1
active
oldest
votes
It's
deriving via (Vector2D a) instance (Additive a) => Additive (Square a)
The way you wrote it, via
looks like a type variable
deriving instance (Additive a) => Additive (Square a) via (Vector2D a)
-- <==>
deriving instance forall a via. (Additive a) => Additive (Square a) (via) (Vector2D a)
and this produces a kind-mismatch error, as Additive (Square a) :: Constraint
is already saturated, but you have applied it to two more arguments.
This is backwards from the shorthand form:
data T' = ...
deriving Class via T
add a comment |
Your Answer
StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});
function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});
}
});
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53403102%2fderiving-via-with-standalone-deriving%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
1 Answer
1
active
oldest
votes
1 Answer
1
active
oldest
votes
active
oldest
votes
active
oldest
votes
It's
deriving via (Vector2D a) instance (Additive a) => Additive (Square a)
The way you wrote it, via
looks like a type variable
deriving instance (Additive a) => Additive (Square a) via (Vector2D a)
-- <==>
deriving instance forall a via. (Additive a) => Additive (Square a) (via) (Vector2D a)
and this produces a kind-mismatch error, as Additive (Square a) :: Constraint
is already saturated, but you have applied it to two more arguments.
This is backwards from the shorthand form:
data T' = ...
deriving Class via T
add a comment |
It's
deriving via (Vector2D a) instance (Additive a) => Additive (Square a)
The way you wrote it, via
looks like a type variable
deriving instance (Additive a) => Additive (Square a) via (Vector2D a)
-- <==>
deriving instance forall a via. (Additive a) => Additive (Square a) (via) (Vector2D a)
and this produces a kind-mismatch error, as Additive (Square a) :: Constraint
is already saturated, but you have applied it to two more arguments.
This is backwards from the shorthand form:
data T' = ...
deriving Class via T
add a comment |
It's
deriving via (Vector2D a) instance (Additive a) => Additive (Square a)
The way you wrote it, via
looks like a type variable
deriving instance (Additive a) => Additive (Square a) via (Vector2D a)
-- <==>
deriving instance forall a via. (Additive a) => Additive (Square a) (via) (Vector2D a)
and this produces a kind-mismatch error, as Additive (Square a) :: Constraint
is already saturated, but you have applied it to two more arguments.
This is backwards from the shorthand form:
data T' = ...
deriving Class via T
It's
deriving via (Vector2D a) instance (Additive a) => Additive (Square a)
The way you wrote it, via
looks like a type variable
deriving instance (Additive a) => Additive (Square a) via (Vector2D a)
-- <==>
deriving instance forall a via. (Additive a) => Additive (Square a) (via) (Vector2D a)
and this produces a kind-mismatch error, as Additive (Square a) :: Constraint
is already saturated, but you have applied it to two more arguments.
This is backwards from the shorthand form:
data T' = ...
deriving Class via T
answered Nov 21 '18 at 1:50
HTNWHTNW
10k1832
10k1832
add a comment |
add a comment |
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53403102%2fderiving-via-with-standalone-deriving%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
1
For what it is worth, I prefer your syntax with
via ...
at the end to the one actually accepted by GHC, wherevia
comes earlier.– chi
Nov 21 '18 at 19:50