libdice/README.md

149 lines
3.1 KiB
Markdown
Raw Normal View History

2018-02-21 12:11:21 +01:00
[![Build Status](https://travis-ci.org/n0la/libdice.svg?branch=master)](https://travis-ci.org/n0la/libdice)
**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
2018-03-23 17:47:43 +01:00
supports variable amount, variable sides and fudge dice at the moment:
2018-02-21 12:11:21 +01:00
* Roll four six sided dices: ``4d6``
* Roll one twenty sided die: ``d20``
2018-03-23 17:47:43 +01:00
* Roll six fudge dice: ``6dF``
2018-02-21 12:11:21 +01:00
## Build
``libdice`` requires:
2018-02-22 13:37:58 +01:00
* libbsd (on systems without a native ``arc4random_uniform``)
2018-02-21 12:11:21 +01:00
* bison
* flex
* cmocka >= 1.0.1
To build ``libdice`` run:
```shell
$ ./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``:
```C
#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:
```C
dice_t d20 = dice_simple(1, 20);
printf("%ld\n", dice_roll(d20));
dice_free(d20);
```
And a more advanced API:
```C
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:
```C
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](https://github.com/codeplea/tinyexpr)
library. The API works with objects of the type ``dice_expression_t``, which
are allocated using ``dice_expression_new``, and must be freed by using
``dice_expression_free``. Expressions in the format of a C string, can be
parsed by using ``dice_expression_parse``, and a result can be evaluated
by using ``dice_expression_roll``.
2018-02-21 12:11:21 +01:00
```C
int error = 0;
char const *expr = "1d20+8+4+3-1";
dice_expression_t e = dice_expression_new();
2018-02-21 12:11:21 +01:00
int64_t result = 0;
if (!dice_expression_parse(e, expr, &err)) {
2018-02-21 12:11:21 +01:00
fprintf(stderr, "error in expression: \"%s\": at %d\n", expr, err);
goto fail;
}
if (!dice_expression_roll(e, &result)) {
2018-02-21 12:11:21 +01:00
goto fail;
}
printf("%ld\n", result);
fail:
dice_expression_free(e);
```
## Copyright
``libdice`` is dual licenced. The ``tinyexpr`` is licenced under the zlib
2018-02-21 13:23:03 +01:00
licence (see ``LICENSE.tinyexpr``), and the rest of ``libdice`` is available
under the LGPLv3.
``tinyexpr`` Copyright (C) 2015, 2016 Lewis Van Winkle
2018-02-21 13:23:37 +01:00
2018-02-21 13:23:03 +01:00
``libdice`` Copyright (C) 2018 Florian Stinglmayr