aboutsummaryrefslogtreecommitdiffstats
path: root/random_unsigned.c
diff options
context:
space:
mode:
authorMattias Andrée <maandree@kth.se>2024-08-18 10:07:51 +0200
committerMattias Andrée <maandree@kth.se>2024-08-18 10:07:51 +0200
commit2de8dae44c40d97e3947070353c1db709a35f92c (patch)
tree13a9827273a54b2a9235135c84eae735ced05009 /random_unsigned.c
parentAdd @since for definitions added in version 1.5 (diff)
parentAdd missing .c files (diff)
downloadlibsimple-2de8dae44c40d97e3947070353c1db709a35f92c.tar.gz
libsimple-2de8dae44c40d97e3947070353c1db709a35f92c.tar.bz2
libsimple-2de8dae44c40d97e3947070353c1db709a35f92c.tar.xz
Merge tag '1.6' into since
Version 1.6
Diffstat (limited to '')
-rw-r--r--random_unsigned.c40
1 files changed, 40 insertions, 0 deletions
diff --git a/random_unsigned.c b/random_unsigned.c
new file mode 100644
index 0000000..f39392d
--- /dev/null
+++ b/random_unsigned.c
@@ -0,0 +1,40 @@
+/* See LICENSE file for copyright and license details. */
+#include "common.h"
+#ifndef TEST
+
+
+uintmax_t
+libsimple_random_unsigned(uintmax_t (*rng)(size_t bits, void *user), void *user, uintmax_t min, uintmax_t max) /* TODO add test */
+{
+ uintmax_t range, offset, t, r;
+ size_t bits = 0;
+
+ if (min < max) {
+ range = max - min;
+ offset = min;
+ } else {
+ range = min - max;
+ offset = max;
+ }
+
+ for (t = range; t; t >>= 1)
+ bits += 1;
+
+ do {
+ r = (*rng)(bits, user);
+ } while (r > range);
+
+ return r + offset;
+}
+
+
+#else
+#include "test.h"
+
+int
+main(void)
+{
+ return 0;
+}
+
+#endif