-
Notifications
You must be signed in to change notification settings - Fork 11
/
Copy pathParseExtract.hs
61 lines (49 loc) · 1.83 KB
/
ParseExtract.hs
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
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
module ParseExtract where
import qualified Data.BitVector as BV
import qualified Data.Array.MArray as M
import qualified Data.Array.IO as A
import qualified Data.Text as T
import qualified Data.Text.IO as T
import qualified Data.Vector as V
import qualified Data.Char as C
import System.IO
import Control.Monad
import Simulator.Util
import Unsafe.Coerce
import qualified Data.Vector.Mutable as MV
import Control.Monad.Primitive
import qualified Data.Vector.Generic as G
mvec_pair_init :: Int -> a -> [(Int,a)] -> IO (MV.MVector (PrimState IO) a)
mvec_pair_init n xdef xs = do
arr <- MV.replicate n xdef
foldM (\_ (i,x) -> MV.write arr i x) () xs
return arr
mvec_fromList :: [a] -> IO (MV.MVector (PrimState IO) a)
mvec_fromList xs = do
let n = length xs
arr <- MV.new n
go arr n 0 xs
where
go arr n _ [] = return arr
go arr n m (x:xs) = if m == n then return arr else do
MV.write arr m x
go arr n (m+1) xs
data Tok = Addr Integer | Value BV.BV deriving (Show)
readTok :: Int -> T.Text -> Tok
readTok n txt = let txt' = T.filter (/= '_') txt in
case T.uncons txt' of
Just ('@',addr) -> Addr $ hex_to_integer addr
Just _ -> Value $ hex_to_bv n txt'
Nothing -> error "Empty text chunk encountered."
toks_to_addr_vals :: [Tok] -> [(Integer, BV.BV)]
toks_to_addr_vals = go 0 where
go _ [] = []
go n ((Addr k):toks) = go k toks
go n ((Value bs):toks) = (n,bs) : go (n+1) toks
getToks :: Int -> T.Text -> [(Integer, BV.BV)]
getToks n text = toks_to_addr_vals $ concat $ map ((map $ readTok n) . (filter (not . T.null)) . (T.split C.isSpace)) $ T.lines text
parseFile :: Int -> Int -> String -> a
parseFile size idxNum path = unsafeCoerce $ do
text <- T.readFile path
let pairs = map (\(i,v) -> (fromIntegral i,v)) $ getToks size $ text
return pairs