Remove code that is dead now that we need >= 6.12 to build
[ghc-hetmet.git] / compiler / main / BreakArray.hs
index 788adf2..4d2c07b 100644 (file)
@@ -1,28 +1,39 @@
+-----------------------------------------------------------------------------
 --
 -- Break Arrays in the IO monad
 -- Entries in the array are Word sized 
 --
+-- Conceptually, a zero-indexed IOArray of Bools, initially False.
+-- They're represented as Words with 0==False, 1==True.
+-- They're used to determine whether GHCI breakpoints are on or off.
+--
+-- (c) The University of Glasgow 2007
+--
+-----------------------------------------------------------------------------
 
 module BreakArray
-  ( BreakArray (BA)
+  ( BreakArray
+#ifdef GHCI
+      (BA)  -- constructor is exported only for ByteCodeGen
+#endif
   , newBreakArray
+#ifdef GHCI
   , getBreak 
   , setBreakOn 
   , setBreakOff
   , showBreakArray
+#endif
   ) where
-
+#ifdef GHCI
 import GHC.Exts
-import GHC.IOBase
-import GHC.Prim
-import GHC.Word
+import GHC.IO ( IO(..) )
 import Constants
 
 data BreakArray = BA (MutableByteArray# RealWorld)
 
 breakOff, breakOn :: Word
-breakOn  = fromIntegral 1
-breakOff = fromIntegral 0
+breakOn  = 1
+breakOff = 0
 
 -- XXX crude
 showBreakArray :: BreakArray -> IO ()
@@ -94,3 +105,14 @@ readBA# array i = IO $ \s ->
 
 readBreakArray :: BreakArray -> Int -> IO Word 
 readBreakArray (BA array) (I# i) = readBA# array i
+
+#else /* GHCI */
+--stub implementation to make main/, etc., code happier.
+--IOArray and IOUArray are increasingly non-portable,
+--still don't have quite the same interface, and (for GHCI)
+--presumably have a different representation.
+data BreakArray = Unspecified
+newBreakArray :: Int -> IO BreakArray
+newBreakArray _ = return Unspecified
+#endif /* GHCI */
+