X-Git-Url: http://git.megacz.com/?a=blobdiff_plain;ds=sidebyside;f=compiler%2FbasicTypes%2FUniqSupply.lhs;fp=compiler%2FbasicTypes%2FUniqSupply.lhs;h=8e3ac96ae540a40317b21584d2618ceb51e45f93;hb=19b0b165a24606dbdb1f4dd7728da7346845a5a0;hp=8dcf595da004124b75fbee654b2b0da9c2aede9a;hpb=a5c802d4a27be911b6cbc23104bcff753867b55a;p=ghc-hetmet.git diff --git a/compiler/basicTypes/UniqSupply.lhs b/compiler/basicTypes/UniqSupply.lhs index 8dcf595..8e3ac96 100644 --- a/compiler/basicTypes/UniqSupply.lhs +++ b/compiler/basicTypes/UniqSupply.lhs @@ -28,6 +28,13 @@ import Unique import GHC.Exts import System.IO.Unsafe ( unsafeInterleaveIO ) +#if __GLASGOW_HASKELL__ >= 607 +import GHC.IOBase (unsafeDupableInterleaveIO) +#else +unsafeDupableInterleaveIO :: IO a -> IO a +unsafeDupableInterleaveIO = unsafeInterleaveIO +#endif + w2i x = word2Int# x i2w x = int2Word# x i2w_s x = (x :: Int#) @@ -69,7 +76,7 @@ mkSplitUniqSupply (C# c#) -- This is one of the most hammered bits in the whole compiler mk_supply# - = unsafeInterleaveIO ( + = unsafeDupableInterleaveIO ( genSymZh >>= \ (I# u#) -> mk_supply# >>= \ s1 -> mk_supply# >>= \ s2 ->