Skip to content

A typescript library that can parse a common roll shorthand, i.e. 2d20, and return the result

License

Notifications You must be signed in to change notification settings

evilmonkeyinc/die-roller

Repository files navigation

Die Roller

A simple library to take die rolling shorthand and return the result

Installing

This library ahs been published to NPM and can be installed with npm or yarn

npm install @evilmonkeyinc/die-roller
yarn add @evilmonkeyinc/die-roller

The library will be compatible with both javascript and typescript

Usage

import { parse } from '@evilmonkeyinc/die-roller'

...

const parsedExpression = parse('4d6k3')
console.log(parsedExpression.result);
// will return a number between 3 and 18

The parse function will take a die expression shorthand and evaluate it and return the result.

The expression should be in the format {number of die}d{size of die}{options}

The options are used to perform simple actions on the die results before giving back the result, such as 2d20k1 which would return the higher of two d20 rolls or 4d6k3 which would return the result of the best three d6 rolls out of 4.

Option Description
k{number} Keep only the highest {number} of die results
kh{number} Keep only the highest {number} of die results
kl{number} Keep only the lowest {number} of die results
d{number} Drop the lowest {number} of die results
dl{number} Drop the lowest {number} of die results
dh{number} Drop the highest {number} of die results

You can also chain expressions, or simply add or subtract whole numbers for the result by appending a + or - to an expression if you need to include modifiers to your results.

1d20+2+3 for your Palidin attacking with their Longsword, with their 2 in proficiency and 3 strength. You hit, and decide to SMITE the enemy, you could then roll 1d8+3+2d8 for damage, 1d8+3 for the weapon and 2d8 for a Divine Smite at 1st level

About

A typescript library that can parse a common roll shorthand, i.e. 2d20, and return the result

Resources

License

Stars

Watchers

Forks

Packages

No packages published