projects
/
ghc-base.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
[project @ 2005-02-01 00:52:20 by ross]
[ghc-base.git]
/
Data
/
STRef.hs
diff --git
a/Data/STRef.hs
b/Data/STRef.hs
index
c60b299
..
3edfb87
100644
(file)
--- a/
Data/STRef.hs
+++ b/
Data/STRef.hs
@@
-1,20
+1,19
@@
-----------------------------------------------------------------------------
-----------------------------------------------------------------------------
---
+-- |
-- Module : Data.STRef
-- Copyright : (c) The University of Glasgow 2001
-- Module : Data.STRef
-- Copyright : (c) The University of Glasgow 2001
--- License : BSD-style (see the file libraries/core/LICENSE)
+-- License : BSD-style (see the file libraries/base/LICENSE)
--
-- Maintainer : libraries@haskell.org
-- Stability : experimental
-- Portability : non-portable (requires non-portable module ST)
--
--
-- Maintainer : libraries@haskell.org
-- Stability : experimental
-- Portability : non-portable (requires non-portable module ST)
--
--- $Id: STRef.hs,v 1.3 2002/03/04 17:25:36 panne Exp $
---
--- Mutable references in the ST monad.
+-- Mutable references in the (strict) ST monad.
--
-----------------------------------------------------------------------------
module Data.STRef (
--
-----------------------------------------------------------------------------
module Data.STRef (
+ -- * STRefs
STRef, -- abstract, instance Eq
newSTRef, -- :: a -> ST s (STRef s a)
readSTRef, -- :: STRef s a -> ST s a
STRef, -- abstract, instance Eq
newSTRef, -- :: a -> ST s (STRef s a)
readSTRef, -- :: STRef s a -> ST s a
@@
-25,10
+24,19
@@
module Data.STRef (
import Prelude
#ifdef __GLASGOW_HASKELL__
import Prelude
#ifdef __GLASGOW_HASKELL__
+import GHC.ST
import GHC.STRef
#endif
import GHC.STRef
#endif
-import Data.Dynamic
+#ifdef __HUGS__
+import Hugs.ST
+#endif
-#include "Dynamic.h"
+import Data.Typeable
+
+#include "Typeable.h"
INSTANCE_TYPEABLE2(STRef,stRefTc,"STRef")
INSTANCE_TYPEABLE2(STRef,stRefTc,"STRef")
+
+-- |Mutate the contents of an 'STRef'
+modifySTRef :: STRef s a -> (a -> a) -> ST s ()
+modifySTRef ref f = writeSTRef ref . f =<< readSTRef ref