2.7 KiB
Warning: The API is not yet stable
libdice
libdice
is a small C library for rolling P&P style dice and for
evaluating dice expressions.
Features
- Written in ANSI C99
- Uses solid and reliable RNG, no need for seeding
- Mathematic expression library for advanced dice rolling
Dice syntax
Currently the supported syntax in libdice
is rather limited. It only
supports variable amount and variable sides at the moment:
- Roll four six sided dices:
4d6
- Roll one twenty sided die:
d20
Build
libdice
requires:
- libbsd
- bison
- flex
- cmocka >= 1.0.1
To build libdice
run:
$ ./configure --prefix="/usr"
$ make
$ sudo make install
Dice API
The core api relies on dice_new
which creates a new dice (or a set of dice),
which is then freed by dice_free
. Dice can be initialised through the proper
dice_set
function, or by using either dice_simple
or dice_parse
:
#include <dice.h>
dice_t d = dice_new();
dice_set(d, DICEOPTION_AMOUNT, 4);
dice_set(d, DICEOPTION_SIDES, 6);
/* or simpler:
* d = dice_simple(4, 6);
*/
printf("%ld\n", dice_roll(d));
dice_free(d);
There is also an easier API:
dice_t d20 = dice_simple(1, 20);
printf("%ld\n", dice_roll(d20));
dice_free(d20);
And a more advanced API:
dice_t d = dice_simple(4, 6);
dice_result_t *res = NULL;
size_t reslen = 0, i = 0;
if (!dice_evaluate(d, &res, &reslen)) {
goto fail;
}
for (; i < reslen; i++) {
printf("%ld\n", res[i].result);
}
fail:
dice_result_freev(res, reslen);
dice_free(d);
You can also parse dice strings:
dice_t d20 = dice_new();
if (!dice_parse(d20, "5d20")) {
char const *err = NULL;
dice_get(d20, DICEOPTION_ERROR, &err);
fprintf(stderr, "error: %s\n", err);
}
printf("%ld\n", dice_roll(d20));
dice_free(d20);
Expression API
The expression API supports multiple die within one mathematical expression. Expressions are parsed using tinyexpr library.
int error = 0;
char const *expr = "1d20+8+4+3-1";
dice_expression_t e = dice_expression_parse(expr, &err);
int64_t result = 0;
if (e == NULL) {
fprintf(stderr, "error in expression: \"%s\": at %d\n", expr, err);
goto fail;
}
if (!dice_expression_evaluate(e, &result)) {
goto fail;
}
printf("%ld\n", result);
fail:
dice_expression_free(e);
Copyright
libdice
is dual licenced. The tinyexpr
is licenced under the zlib
licence (see LICENSE.tinyexpr
), and the rest of libdice
is available
under the LGPLv3.
tinyexpr
Copyright (C) 2015, 2016 Lewis Van Winkle
libdice
Copyright (C) 2018 Florian Stinglmayr