alea/Alea/Diceware.hs

36 lines
817 B
Haskell
Raw Permalink Normal View History

2014-10-14 18:09:58 +02:00
module Alea.Diceware where
2014-10-13 21:26:55 +02:00
import qualified Data.Map as Map
2014-10-14 18:09:58 +02:00
import Alea.List
2014-10-13 21:26:55 +02:00
-- Diceware dictionary type
type Diceware = Map.Map Int String
-- Parse a line into a tuple
parseLine :: String -> (Int, String)
parseLine x =
(read a :: Int, b)
where
x' = split x ' '
(a, b) = (head x', last x')
-- Parse file content to a Diceware
parseDiceware :: String -> Diceware
parseDiceware x = (Map.fromList . map parseLine . lines) x
-- Lookup word with dice index
readDiceware :: Diceware -> Int -> String
readDiceware d n =
show n ++ " -> " ++
case Map.lookup n d of
Just x -> x
Nothing -> "Does not exist"
-- Lookup word with linear index
readDiceware' :: Diceware -> Int -> String
readDiceware' d n = (snd . (!!n) . Map.toList) d
-- Size of Diceware (should be 2^5)
size :: Diceware -> Int
size = Map.size