summaryrefslogtreecommitdiff
path: root/testsuite/tests/array/should_run/arr014.hs
blob: 59541c09ff056d19a189c4043332e87fdea23823 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
-- !!! multi-dimensional arrays

module Main ( main ) where
import Control.Monad.ST
import Data.Array.ST

type TwoD s = STArray s Int (STArray s Int Int)

setup :: ST s (TwoD s)
setup = let isz = 10
            imax = isz - 1	  
            osz = 2
            omax = osz - 1 in
	do
            -- gives : undefined reference to `IOBase_error_closure'
--	    x <- newArray (0, omax) (error "uninitialised")
	    dmy <- newArray (0, imax) 0      
	    x <- newArray (0, omax) dmy
	    as <- (sequence . replicate osz) (newArray (0, imax) 6)
	    mapM_ (\(i,v) -> writeArray x i v) (zip [0..omax] as)
	    return x	  

main :: IO ()
main = do
         a <- stToIO setup
	 return ()