Clojure(script) library that parses Dungeons & Dragons dice rolls (e.g. 1d20
)
and rolls them.
- Parsing dice notation, e.g.
d20
,2d6+1
,2x5d5
.- Most stuff of the dice notation is supported in the parser.
- Parsed rolls are edn data structures, so they can be serialized.
- Rolling (parsed) dice.
- Support for dice arithmetic (e.g.
1d20x1d20
) - Support for fudge dice syntax
- Support for exploding dice syntax
DnDDice is available as a Maven artifact from Clojars.
With deps.edn:
{org.fversnel/dnddice {:mvn/version "4.1.0"}}
With Leiningen/Boot:
[org.fversnel/dnddice "4.1.0"]
Require the following namespace:
(ns example.core
(:require [org.fversnel.dnddice.core :as dnddice]))
You can use the library as follows:
(def d20 (dnddice/parse "d20")) ; {:sides 20}
=> (dnddice/roll d20)
{:roll {:sides 20},
:die-rolls (5),
:total 5}
=> (dnddice/roll (dnddice/parse "1d20"))
{:roll {:sides 20, :die-count 1},
:die-rolls (7),
:total 7}
=> (dnddice/roll (dnddice/parse "2d5+1"))
{:roll {:modifier {:operator '+, :value 1}, :sides 5, :die-count 2},
:die-rolls (1 2),
:total 4}
; Or roll directly
=> (dnddice/roll "1d20")
{:roll {:sides 20, :die-count 1},
:die-rolls (16),
:total 16}
; Drop highest result
(dnddice/roll "5d10-H") ; Use -L for drop lowest
{:roll {:die-count 5, :sides 10, :drop :highest},
:die-rolls (7 5 9 9),
:total 30}
; Roll percentile dice
=> (dnddice/roll "d%")
{:roll {:sides "%"}, :die-rolls (79), :total 79}
; Parse and then re-construct
=> (dnddice/dice-expression (dnddice/parse "5d20+10"))
"5d20+10"
Copyright © 2013-2021 Frank Versnel
Distributed under the Eclipse Public License, the same as Clojure.