2 * Copyright © 2012, 2020, 2022-2023 Nick Bowler
4 * This program is free software: you can redistribute it and/or modify
5 * it under the terms of the GNU General Public License as published by
6 * the Free Software Foundation, either version 3 of the License, or
7 * (at your option) any later version.
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 * GNU General Public License for more details.
14 * You should have received a copy of the GNU General Public License
15 * along with this program. If not, see <https://www.gnu.org/licenses/>.
30 #define MIN(a, b) ((a) < (b) ? (a) : (b))
32 struct cdecl_declspec;
38 void *malloc_nofail(size_t size);
39 void *realloc_nofail(void *ptr, size_t size);
41 bool test_strtoumax(uintmax_t *out, const char *s, uintmax_t limit);
43 static inline bool test_strtoul(unsigned long *val, const char *str)
48 rc = test_strtoumax(&v, str, (unsigned long)-1);
53 void test_print_options(const struct option *lopts);
56 * Allocate a new random number generator with the given seed string (which
57 * should normally be a command-line argument). The string is parsed as an
58 * integer value as if by strtoull with a base of 0.
60 struct test_rng *test_rng_alloc(const char *seed);
63 * Free the random number generator rng.
65 void test_rng_free(struct test_rng *rng);
68 * Return a random integer uniformly on the closed interval [0, limit-1]
70 unsigned test_rng_uniform_int(struct test_rng *rng, unsigned limit);
73 * Return false or true with 50% probablility either way.
75 static inline int test_rng_50_50(struct test_rng *rng)
77 return test_rng_uniform_int(rng, 2) == 0;
80 #define VERSION_NO_COPYRIGHT_SYMBOL 1
83 #define test_print_version(s) \
84 do_print_version(s " (" PACKAGE_NAME ") " PACKAGE_VERSION)