npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

complex-dice

v1.1.1

Published

An die roller of complex proportions. N-DdF(+/-N-DdF)*

Downloads

1

Readme

#Complex Dice Roller

A Roller for increasingly complex die patterns. There are two Objects - DiceGroups, and Rolls.

##DiceGroup

A dice group is of the format:

N-DdSxM/V

All numbers must be integers.

###N

Roll N dice. This is the only required portion of the definition.

###D

Drop the lowest D dice. Defaults to 0

###dS

All dice roll between 1 and S. Defaults to d1.

###xM

Multiply the sum of the chosen Dice by the multiplier M. Defaults to x1.

Note that this means 2-1x2 is equal to 2, not 0.

###/V

Divide the sum of the chosen Dice by the divisor V, rounding down. Defaults to /1.

Note that this means 2-1x2 is equal to 2, not 0.

##Roll

A roll is just a series of DiceGroups, joined by + or -. You can mix or match pluses or minuses, and different types of DiceGroups.

Note that this matching is greedy - 4-1d6 will be interpreted as a single DiceGroup, not 4 and -1d6.

##Usage

var DiceGroup = require('complex-dice').DiceGroup
var Roll = require('complex-dice').Roll

var dg = new DiceGroup('4-1d6'); //Stats
console.log(dg.max()); //18
console.log(dg.min()); //3
console.log(dg.roll()); //somewhere between 3 and 18
console.log(dg.getDefinition()); //4-1d6

var roll = new Roll('1d4+1'); //Magic Missile!
console.log(roll.max()); //5
console.log(roll.min()); //2
console.log(roll.roll()); //Something between 2 and 5
console.log(roll.getDefinition()); //1d4+1

##Testing

If you're attempting to test this code you can do so with mocha. Just run it. It'll be great!

If you're using this code in your application, you can use the Mocks that are packaged with this application. All you have do to is install sinon:

npm install --save-dev sinon

Then you can grab our bundled Mocks:

var DiceGroup = require('complex-dice').mock.DiceGroup
var Roll = require('complex-dice').mock.Roll

var dg = new DiceGroup('4-1d6'); //Stats
console.log(dg.max()); //1
console.log(dg.min()); //1
console.log(dg.roll()); //1
dg.reset();
console.log(dg.max.callCount) //0
console.log(dg.getDefinition()); //4-1d6

var roll = new Roll('1d4+1'); //Magic Missile!
console.log(roll.max()); //1
console.log(roll.min()); //1
console.log(roll.roll()); //1
roll.reset();
console.log(roll.max.callCount) //0
console.log(roll.getDefinition()); //1d4+1

As you can see, our mocks support the same interface as the actual classes, with two major differences:

  1. All mathematical functions (max, roll, min) are sinon stubs that return 1.
  2. The additional reset() function resets all stubs via stub.reset().

Contributing

Please maintain the existing style - but do open a pull request if you have a bugfix or a cool feature. Be sure to document your change. Pull requests are preferred to bug reports (though if you submit a bug report, you're welcome to fix your own bug).

Please be sure to update all documentation to reflect your changes - add to the Readme files and the in code commenting.