[GHC] #14154: Some cocktail of features causes GHC panic
GHC
ghc-devs at haskell.org
Thu Aug 24 19:43:03 UTC 2017
#14154: Some cocktail of features causes GHC panic
-------------------------------------+-------------------------------------
Reporter: Iceland_jack | Owner: (none)
Type: bug | Status: new
Priority: normal | Milestone:
Component: Compiler | Version: 8.3
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: |
-------------------------------------+-------------------------------------
Description changed by Iceland_jack:
Old description:
> {{{#!hs
> {-# Language RankNTypes, DerivingStrategies, TypeApplications,
> ScopedTypeVariables, GADTs, GeneralizedNewtypeDeriving, InstanceSigs,
> PolyKinds #-}
>
> import Data.Coerce
>
> newtype Ran g h a = Ran (forall b. (a -> g b) -> h b)
>
> newtype Swap p f g a where
> Swap :: p g f a -> Swap p f g a
> deriving newtype
> Show
>
> class IxPointed m where
> ireturn :: a -> m i i a
>
> instance IxPointed f => IxPointed (Swap f) where
> ireturn :: forall a i. a -> Swap f i i a
> ireturn = coerce (ireturn @f @a @i)
>
> instance IxPointed Ran where
> ireturn :: a -> Ran i i a
> ireturn a = Ran (\k -> k a)
>
> xs =
> case ireturn @(Swap Main.Ran) 'a' of
> Swap (Ran f) -> f print
> }}}
>
> {{{
> $ ghci -ignore-dot-ghci /tmp/bug.hs
> GHCi, version 8.3.20170605: http://www.haskell.org/ghc/ :? for help
> [1 of 1] Compiling Main ( /tmp/bug.hs, interpreted )
> ghc: panic! (the 'impossible' happened)
> (GHC version 8.3.20170605 for x86_64-unknown-linux):
> piResultTy
> k0_a1Ki[tau:2]
> b0_a1Kt[tau:2]
> Call stack:
> CallStack (from HasCallStack):
> prettyCurrentCallStack, called at
> compiler/utils/Outputable.hs:1133:58 in ghc:Outputable
> callStackDoc, called at compiler/utils/Outputable.hs:1137:37 in
> ghc:Outputable
> pprPanic, called at compiler/types/Type.hs:949:35 in ghc:Type
>
> Please report this as a GHC bug: http://www.haskell.org/ghc/reportabug
>
> >
> }}}
New description:
{{{#!hs
{-# Language RankNTypes, DerivingStrategies, TypeApplications,
ScopedTypeVariables, GADTs, GeneralizedNewtypeDeriving, InstanceSigs,
PolyKinds #-}
import Data.Coerce
newtype Ran g h a = Ran (forall b. (a -> g b) -> h b)
newtype Swap p f g a where
Swap :: p g f a -> Swap p f g a
deriving newtype
Show
class IxPointed m where
ireturn :: a -> m i i a
instance IxPointed f => IxPointed (Swap f) where
ireturn :: forall a i. a -> Swap f i i a
ireturn = coerce (ireturn @f @a @i)
instance IxPointed Ran where
ireturn :: a -> Ran i i a
ireturn a = Ran (\k -> k a)
xs =
case ireturn @(Swap Ran) 'a' of
Swap (Ran f) -> f print
}}}
{{{
$ ghci -ignore-dot-ghci /tmp/bug.hs
GHCi, version 8.3.20170605: http://www.haskell.org/ghc/ :? for help
[1 of 1] Compiling Main ( /tmp/bug.hs, interpreted )
ghc: panic! (the 'impossible' happened)
(GHC version 8.3.20170605 for x86_64-unknown-linux):
piResultTy
k0_a1Ki[tau:2]
b0_a1Kt[tau:2]
Call stack:
CallStack (from HasCallStack):
prettyCurrentCallStack, called at
compiler/utils/Outputable.hs:1133:58 in ghc:Outputable
callStackDoc, called at compiler/utils/Outputable.hs:1137:37 in
ghc:Outputable
pprPanic, called at compiler/types/Type.hs:949:35 in ghc:Type
Please report this as a GHC bug: http://www.haskell.org/ghc/reportabug
>
}}}
--
--
Ticket URL: <http://ghc.haskell.org/trac/ghc/ticket/14154#comment:2>
GHC <http://www.haskell.org/ghc/>
The Glasgow Haskell Compiler
More information about the ghc-tickets
mailing list