sheet-parser-hs/lib/DND/Dice.hs

35 lines
908 B
Haskell
Raw Normal View History

module DND.Dice
( rolls
, d20
2024-12-01 17:35:24 +01:00
, rollCheck
, rollAttackDamage
, RollMod(..)
) where
2024-12-01 17:35:24 +01:00
import Prelude hiding (mod)
2024-11-18 17:24:26 +01:00
import System.Random
2024-12-01 17:35:24 +01:00
data RollMod = Advantage | Disadvantage | Neutral
rolls :: RandomGen a => a -> Int -> Int -> [Int]
rolls rnd x y = take x . randomRs (1, y) $ rnd
d20 :: RandomGen a => a -> Int
2024-12-01 17:35:24 +01:00
d20 rnd = minimum $ rolls rnd 1 20
rollCheck :: Int -> RollMod -> IO (Int, [Int])
rollCheck scoreMod rollMod = do
rnd <- getStdGen
let dice = rolls rnd 2 20
mod = (+) scoreMod $ case rollMod of
Advantage -> maximum dice
Disadvantage -> minimum dice
Neutral -> head dice
return (mod,dice)
2024-12-01 17:35:24 +01:00
rollAttackDamage :: Int -> Int -> Int -> IO Int
-- dmgMod is proficiency in normal DND rules
rollAttackDamage sides count dmgMod = do
rnd <- getStdGen
return $ (+) dmgMod . sum $ rolls rnd sides count