SafeHaskell: Update to work with safe base
[ghc.git] / compiler / basicTypes / UniqSupply.lhs
index 774d2d2..4e1de6a 100644 (file)
@@ -8,15 +8,16 @@ module UniqSupply (
         -- * Main data type
         UniqSupply, -- Abstractly
 
-        -- ** Operations on supplies 
+        -- ** Operations on supplies
         uniqFromSupply, uniqsFromSupply, -- basic ops
-        
+        takeUniqFromSupply,
+
         mkSplitUniqSupply,
         splitUniqSupply, listSplitUniqSupply,
 
         -- * Unique supply monad and its abstraction
         UniqSM, MonadUnique(..),
-        
+
         -- ** Operations on the monad
         initUs, initUs_,
         lazyThenUs, lazyMapUs,
@@ -28,16 +29,10 @@ module UniqSupply (
 import Unique
 import FastTypes
 
+import GhcIO (unsafeDupableInterleaveIO)
+
 import MonadUtils
 import Control.Monad
-import Control.Monad.Fix
-#if __GLASGOW_HASKELL__ >= 607
-import GHC.IOBase (unsafeDupableInterleaveIO)
-#else
-import System.IO.Unsafe ( unsafeInterleaveIO )
-unsafeDupableInterleaveIO :: IO a -> IO a
-unsafeDupableInterleaveIO = unsafeInterleaveIO
-#endif
 
 \end{code}
 
@@ -73,6 +68,8 @@ uniqFromSupply  :: UniqSupply -> Unique
 -- ^ Obtain the 'Unique' from this particular 'UniqSupply'
 uniqsFromSupply :: UniqSupply -> [Unique] -- Infinite
 -- ^ Obtain an infinite list of 'Unique' that can be generated by constant splitting of the supply
+takeUniqFromSupply :: UniqSupply -> (Unique, UniqSupply)
+-- ^ Obtain the 'Unique' from this particular 'UniqSupply', and a new supply
 \end{code}
 
 \begin{code}
@@ -101,6 +98,7 @@ listSplitUniqSupply  (MkSplitUniqSupply _ s1 s2) = s1 : listSplitUniqSupply s2
 \begin{code}
 uniqFromSupply  (MkSplitUniqSupply n _ _)  = mkUniqueGrimily (iBox n)
 uniqsFromSupply (MkSplitUniqSupply n _ s2) = mkUniqueGrimily (iBox n) : uniqsFromSupply s2
+takeUniqFromSupply (MkSplitUniqSupply n s1 _) = (mkUniqueGrimily (iBox n), s1)
 \end{code}
 
 %************************************************************************