[GHC] #14824: automatically select instance
GHC
ghc-devs at haskell.org
Thu Feb 22 10:17:47 UTC 2018
#14824: automatically select instance
-------------------------------------+-------------------------------------
Reporter: zaoqi | Owner: (none)
Type: feature request | Status: new
Priority: normal | Milestone:
Component: Compiler | Version: 8.2.2
Resolution: | Keywords:
Operating System: Unknown/Multiple | Architecture:
| Unknown/Multiple
Type of failure: None/Unknown | Test Case:
Blocked By: | Blocking:
Related Tickets: | Differential Rev(s):
Wiki Page: |
-------------------------------------+-------------------------------------
Comment (by zaoqi):
Replying to [comment:9 AntC]:
> Thank you zaoqi. The ticket is now very different to your first post.
>
> GHC is behaving as I would expect. It doesn't know which instance of `C`
to select for the invocation of `m`. That's because it doesn't know the
type of the result for `m [X1]`. You could go:
>
> {{{
> *Main> m [X1] :: X2
> }}}
>
> And get result `X2`, because GHC can select `instance C X1 X2`.
>
> That's similar to `read "5" :: Int` vs `read "5" :: Float` to
disambiguate number formats.
>
> GHC does not automatically select an instance just because it seems to
be the only one that fits: maybe there is another instance declared in
another module that fits just as well.
>
> I could tell you about `FunctionalDependencies` combined with
`OverlappingInstances` and `UndecidableInstances`. But first consider
whether Closed `TypeFamilies` will provide a better approach.
>
> I can't see any fault. I can't see any "new feature" needed. Please do
not use Trac tickets for help requests.
I think they are "new feature" or "bug", I never use Trac tickets for help
requests.
--
Ticket URL: <http://ghc.haskell.org/trac/ghc/ticket/14824#comment:10>
GHC <http://www.haskell.org/ghc/>
The Glasgow Haskell Compiler
More information about the ghc-tickets
mailing list