[GHC] #15532: Relaxing Levity-Polymorphic Binder Check for Lifted vs Unlifted pointers

GHC ghc-devs at haskell.org
Fri Aug 17 15:03:38 UTC 2018


#15532: Relaxing Levity-Polymorphic Binder Check for Lifted vs Unlifted pointers
-------------------------------------+-------------------------------------
        Reporter:  andrewthad        |                Owner:  (none)
            Type:  feature request   |               Status:  new
        Priority:  normal            |            Milestone:  8.6.1
       Component:  Compiler          |              Version:  8.4.3
      Resolution:                    |             Keywords:
                                     |  LevityPolymorphism
Operating System:  Unknown/Multiple  |         Architecture:
                                     |  Unknown/Multiple
 Type of failure:  None/Unknown      |            Test Case:
      Blocked By:                    |             Blocking:
 Related Tickets:  14917             |  Differential Rev(s):
       Wiki Page:                    |
-------------------------------------+-------------------------------------

Comment (by andrewthad):

 This example also works:

 {{{
 {-# LANGUAGE BangPatterns #-}
 {-# LANGUAGE MagicHash #-}
 {-# LANGUAGE RankNTypes #-}
 {-# LANGUAGE UnboxedTuples #-}
 {-# LANGUAGE TypeInType #-}

 import Data.Primitive
 import Data.Primitive.UnliftedArray
 import GHC.Types
 import GHC.Exts

 main :: IO ()
 main = do
   a@(Array myArr) <- newArray 1 ("foo" :: String) >>= unsafeFreezeArray
   UnliftedArray myArrArr <- newUnliftedArray 1 a >>=
 unsafeFreezeUnliftedArray
   putStrLn (example even show (show . (+1)) (5 :: Integer))
   let r = exampleUnlifted
         (\x -> isTrue# (sizeofArrayArray# x ># 1#))
         (\x -> array# (indexUnliftedArray (UnliftedArray x) 1 :: Array
 String))
         (\x -> array# (indexUnliftedArray (UnliftedArray x) 0 :: Array
 String))
         myArrArr
       !(# e #) = indexArray# r 0#
   putStrLn e

 {-# NOINLINE example #-}
 example :: (a -> Bool) -> (a -> b) -> (a -> b) -> a -> b
 example p f g a = if p a then f a else g a

 exampleUnlifted :: forall (a :: TYPE 'UnliftedRep) (b :: TYPE
 'UnliftedRep).
   (a -> Bool) -> (a -> b) -> (a -> b) -> a -> b
 exampleUnlifted = unsafeCoerce# example
 }}}

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


More information about the ghc-tickets mailing list