Deriving Via With Standalone Deriving












3















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










share|improve this question




















  • 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
















3















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










share|improve this question




















  • 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














3












3








3


1






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










share|improve this question
















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






share|improve this question















share|improve this question













share|improve this question




share|improve this question








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 with via ... at the end to the one actually accepted by GHC, where via comes earlier.

    – chi
    Nov 21 '18 at 19:50














  • 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








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












1 Answer
1






active

oldest

votes


















9














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





share|improve this answer























    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
    });


    }
    });














    draft saved

    draft discarded


















    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









    9














    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





    share|improve this answer




























      9














      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





      share|improve this answer


























        9












        9








        9







        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





        share|improve this answer













        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






        share|improve this answer












        share|improve this answer



        share|improve this answer










        answered Nov 21 '18 at 1:50









        HTNWHTNW

        10k1832




        10k1832






























            draft saved

            draft discarded




















































            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.




            draft saved


            draft discarded














            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





















































            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







            Popular posts from this blog

            MongoDB - Not Authorized To Execute Command

            How to fix TextFormField cause rebuild widget in Flutter

            in spring boot 2.1 many test slices are not allowed anymore due to multiple @BootstrapWith