| Prev | Next | 
type Resource = TVar Int
 putR :: Resource -> Int -> STM ()
 putR r i = do { v <- readTVar r
               ; writeTVar r (v+i) }
 getR :: Resource -> Int -> STM ()
 getR r i = do { v <- readTVar r
               ; if (v < i) then retry
                 else writeTVar r (v-i) }
atomic ( getR r x ) atomic ( putR r x )
| 2 |