2024-11-18 17:09:16 +01:00
|
|
|
module DND.Dice
|
|
|
|
( rolls
|
|
|
|
, d20
|
2024-12-01 17:35:24 +01:00
|
|
|
, rollCheck
|
|
|
|
, rollAttackDamage
|
|
|
|
, RollMod(..)
|
2024-11-18 17:09:16 +01:00
|
|
|
) 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-11-18 17:09:16 +01:00
|
|
|
|
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
|
2024-11-18 17:09:16 +01:00
|
|
|
|
|
|
|
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-11-18 17:09:16 +01:00
|
|
|
|
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
|