Core Lint warning (Unsafe coercion: {left,right}-hand type is levity-polymorphic)
goldfire claims this is a GHC bug, so I'm reporting it here:
{-# LANGUAGE DataKinds #-}
{-# LANGUAGE GADTs #-}
{-# LANGUAGE PolyKinds #-}
{-# LANGUAGE ScopedTypeVariables #-}
{-# LANGUAGE TypeFamilies #-}
module Bug where
import Data.Kind (Type)
import GHC.Exts (TYPE)
import Type.Reflection (TypeRep, (:~~:)(..), eqTypeRep)
import Unsafe.Coerce (unsafeCoerce)
data SBool :: Bool -> Type where
SFalse :: SBool False
STrue :: SBool True
type family DefaultEq (a :: k) (b :: k) :: Bool where
DefaultEq a a = 'True
DefaultEq a b = 'False
sEqTypeRep :: forall rep (x :: TYPE rep) (y :: TYPE rep).
TypeRep x -> TypeRep y -> SBool (DefaultEq x y)
sEqTypeRep tra trb =
case eqTypeRep tra trb of
Just HRefl -> STrue
Nothing -> unsafeCoerce SFalse
$ /opt/ghc/8.6.3/bin/ghc Bug.hs -O -dcore-lint -fforce-recomp
[1 of 1] Compiling Bug ( Bug.hs, Bug.o )
*** Core Lint warnings : in result of Simplifier ***
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: left-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: right-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
*** Core Lint warnings : in result of Simplifier ***
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: left-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: right-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
*** Core Lint warnings : in result of Simplifier ***
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: left-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: right-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
*** Core Lint warnings : in result of Simplifier ***
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: left-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: right-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
*** Core Lint warnings : in result of Float inwards ***
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: left-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: right-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
*** Core Lint warnings : in result of Called arity analysis ***
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: left-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: right-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
*** Core Lint warnings : in result of Simplifier ***
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: left-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: right-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
*** Core Lint warnings : in result of Demand analysis ***
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: left-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: right-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
*** Core Lint warnings : in result of Worker Wrapper binds ***
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: left-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: right-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: left-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: right-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
*** Core Lint warnings : in result of Simplifier ***
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: left-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: right-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: left-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: right-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
*** Core Lint warnings : in result of Exitification transformation ***
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: left-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: right-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: left-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: right-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
*** Core Lint warnings : in result of Float out(FOS {Lam = Just 0,
Consts = True,
OverSatApps = True}) ***
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: left-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: right-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: left-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: right-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
*** Core Lint warnings : in result of Common sub-expression ***
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: left-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: right-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: left-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: right-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
*** Core Lint warnings : in result of Float inwards ***
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: left-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: right-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: left-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: right-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
*** Core Lint warnings : in result of Simplifier ***
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: left-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: right-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: left-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: right-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
*** Core Lint warnings : in result of Simplifier ***
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: left-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: right-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: left-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: right-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
*** Core Lint warnings : in result of Demand analysis ***
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: left-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: right-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: left-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: right-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
*** Core Lint warnings : in result of Tidy Core ***
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: left-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: right-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: left-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: right-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
*** Core Lint warnings : in result of CorePrep ***
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: left-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
<no location info>: warning:
In a case alternative: (True)
Unsafe coercion: right-hand type is levity-polymorphic
From: x_a1rf
To: y_a1rg
Trac metadata
Trac field | Value |
---|---|
Version | 8.6.3 |
Type | Bug |
TypeOfFailure | OtherFailure |
Priority | normal |
Resolution | Unresolved |
Component | Compiler |
Test case | |
Differential revisions | |
BlockedBy | |
Related | |
Blocking | |
CC | |
Operating system | |
Architecture |