[GHC] #11016: PartialTypeSignatures trigger bogus "unbound implicit parameter" error

GHC ghc-devs at haskell.org
Sun Oct 25 23:56:40 UTC 2015


#11016: PartialTypeSignatures trigger bogus "unbound implicit parameter" error
-------------------------------------+-------------------------------------
           Reporter:  gridaphobe     |             Owner:
               Type:  bug            |            Status:  new
           Priority:  normal         |         Milestone:
          Component:  Compiler       |           Version:  7.10.2
           Keywords:                 |  Operating System:  Unknown/Multiple
       Architecture:                 |   Type of failure:  GHC rejects
  Unknown/Multiple                   |  valid program
          Test Case:                 |        Blocked By:
           Blocking:                 |   Related Tickets:  #10846
Differential Rev(s):                 |         Wiki Page:
-------------------------------------+-------------------------------------
 GHC seems to forget about in-scope implicit parameters when there's a hole
 in the type signature. Given

 {{{#!haskell
 {-# LANGUAGE ImplicitParams, PartialTypeSignatures #-}

 module Bad where

 f1 :: (?loc :: Int, _) => Int
 f1 = ?loc

 f2 :: (?loc :: Int) => _
 f2 = ?loc
 }}}

 GHC incorrectly reports the following errors.

 {{{
 % ghc -fforce-recomp Bad.hs
 [1 of 1] Compiling Bad              ( Bad.hs, Bad.o )

 Bad.hs:8:6:
     Unbound implicit parameter (?loc::Int)
       arising from a use of implicit parameter ‘?loc’
     In the expression: ?loc
     In an equation for ‘f1’: f1 = ?loc

 Bad.hs:11:1:
     Occurs check: cannot construct the infinite type:
       _ ~ (?loc::Int) => _
     When checking that ‘f2’ has the specified type
       f2 :: (?loc::Int) => _
     Probable cause: the inferred type is ambiguous

 Bad.hs:11:6:
     Unbound implicit parameter (?loc::_)
       arising from a use of implicit parameter ‘?loc’
     Relevant bindings include f2 :: _ (bound at Bad.hs:11:1)
     In the expression: ?loc
     In an equation for ‘f2’: f2 = ?loc
 }}}

 `?loc` is very clearly bound by both `f1` and `f2`'s signature. `f2`
 additionally reports what looks to me to be a bogus occurs-check error; we
 know from the theta that `?loc :: Int` so the hole should be solved for
 `Int`.

 I suspect this is all related to the fact that PartialTypeSignatures
 triggers `tcPolyInfer` instead of `tcPolyCheck`.

 I think this is the same underlying bug as #10846.

--
Ticket URL: <http://ghc.haskell.org/trac/ghc/ticket/11016>
GHC <http://www.haskell.org/ghc/>
The Glasgow Haskell Compiler


More information about the ghc-tickets mailing list