[GHC] #11305: TC Regression
GHC
ghc-devs at haskell.org
Mon Dec 28 16:00:10 UTC 2015
#11305: TC Regression
-------------------------------------+-------------------------------------
Reporter: hvr | Owner:
Type: bug | Status: new
Priority: highest | Milestone: 8.0.1
Component: Compiler | Version: 7.11
(Type checker) |
Keywords: | Operating System: Unknown/Multiple
Architecture: | Type of failure: None/Unknown
Unknown/Multiple |
Test Case: | Blocked By:
Blocking: | Related Tickets:
Differential Rev(s): | Wiki Page:
-------------------------------------+-------------------------------------
TODO: figure out better summary ;-)
The following snippet extracted from Edward's `profunctors` package
compiles with GHC 7.10.3, but fails to type-check with GHC HEAD:
{{{#!hs
{-# LANGUAGE RankNTypes #-}
{-# LANGUAGE TypeOperators #-}
module Data.Profunctor.Strong where
import Control.Arrow
import Control.Category
import Data.Tuple
import Prelude hiding (id,(.))
infixr 0 :->
type p :-> q = forall a b. p a b -> q a b
class Profunctor p where
dimap :: (a -> b) -> (c -> d) -> p b c -> p a d
class ProfunctorFunctor t where
promap :: Profunctor p => (p :-> q) -> t p :-> t q
class ProfunctorFunctor t => ProfunctorMonad t where
proreturn :: Profunctor p => p :-> t p
projoin :: Profunctor p => t (t p) :-> t p
class ProfunctorFunctor t => ProfunctorComonad t where
proextract :: Profunctor p => t p :-> p
produplicate :: Profunctor p => t p :-> t (t p)
class Profunctor p => Strong p where
first' :: p a b -> p (a, c) (b, c)
first' = dimap swap swap . second'
second' :: p a b -> p (c, a) (c, b)
second' = dimap swap swap . first'
----------------------------------------------------------------------------
newtype Tambara p a b = Tambara { runTambara :: forall c. p (a, c) (b, c)
}
instance Profunctor p => Profunctor (Tambara p) where
dimap f g (Tambara p) = Tambara $ dimap (first f) (first g) p
instance ProfunctorFunctor Tambara where
promap f (Tambara p) = Tambara (f p)
instance ProfunctorComonad Tambara where
proextract (Tambara p) = dimap (\a -> (a,())) fst p
produplicate (Tambara p) = Tambara (Tambara $ dimap hither yon p)
where
hither :: ((a, b), c) -> (a, (b, c))
hither ~(~(x,y),z) = (x,(y,z))
yon :: (a, (b, c)) -> ((a, b), c)
yon ~(x,~(y,z)) = ((x,y),z)
instance Profunctor p => Strong (Tambara p) where
first' = runTambara . produplicate
}}}
{{{
Strong.hs:57:12: error:
• Couldn't match type ‘Tambara p (a, c) (b, c)’ with ‘forall c1.
Tambara p (a, c1) (b, c1)’
Expected type: Tambara (Tambara p) a b -> Tambara p (a, c) (b, c)
Actual type: Tambara (Tambara p) a b -> forall c. Tambara p (a, c)
(b, c)
• In the first argument of ‘(.)’, namely ‘runTambara’
In the expression: runTambara . produplicate
In an equation for ‘first'’: first' = runTambara . produplicate
• Relevant bindings include first' :: Tambara p a b -> Tambara p (a,
c) (b, c) (bound at Strong.hs:57:3)
}}}
--
Ticket URL: <http://ghc.haskell.org/trac/ghc/ticket/11305>
GHC <http://www.haskell.org/ghc/>
The Glasgow Haskell Compiler
More information about the ghc-tickets
mailing list