67 lines
1.5 KiB
C
Raw Normal View History

2022-11-19 20:28:13 +01:00
/******************************************************************************/
/* HashSet for C99, by LoRd_MuldeR <MuldeR2@GMX.de> */
/* This work has been released under the CC0 1.0 Universal license! */
/******************************************************************************/
2022-11-19 17:34:56 +01:00
#define _CRT_RAND_S 1
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
2022-11-19 22:34:33 +01:00
#include <string.h>
2022-11-19 17:34:56 +01:00
#include "hash_set.h"
static uint64_t next_rand(void)
{
uint32_t a, b;
if (rand_s(&a) || rand_s(&b))
{
abort();
}
return (((uint64_t)a) << 32) | b;
}
int main()
{
2022-11-19 22:34:33 +01:00
uint8_t spinner = 0U;
clock_t last_update = clock();
2022-11-19 22:34:33 +01:00
2022-11-19 23:21:14 +01:00
hash_set_t *const hash_set = hash_set_create(0U, -1.0, HASHSET_OPT_FAILFAST);
2022-11-19 22:34:33 +01:00
if (!hash_set)
2022-11-19 17:34:56 +01:00
{
puts("Allocation has failed!");
return EXIT_FAILURE;
}
for (;;)
{
2022-11-19 22:34:33 +01:00
const errno_t error = hash_set_insert(hash_set, next_rand() & 0x3FFFFFFFFFFFFFFllu);
2022-11-19 20:28:13 +01:00
if (error)
2022-11-19 17:34:56 +01:00
{
2022-11-20 16:48:14 +01:00
printf("Insert operation has failed! (error: %d)\n", error);
2022-11-19 17:34:56 +01:00
break;
}
2022-11-19 18:42:09 +01:00
if (!(++spinner & 0x7F))
2022-11-19 17:34:56 +01:00
{
2022-11-19 18:42:09 +01:00
const clock_t now = clock();
2022-11-19 22:34:33 +01:00
if ((now < last_update) || (now >= last_update + CLOCKS_PER_SEC))
2022-11-19 18:42:09 +01:00
{
2022-11-21 15:02:07 +01:00
size_t capacity, valid, deleted, limit;
if (!hash_set_info(hash_set, &capacity, &valid, &deleted, &limit))
{
printf("%010zu, %010zu, %010zu, %010zu\n", capacity, valid, deleted, limit);
}
else
{
printf("%zu\n", hash_set_size(hash_set));
}
2022-11-19 22:34:33 +01:00
last_update = now;
2022-11-19 18:42:09 +01:00
}
2022-11-19 17:34:56 +01:00
}
}
2022-11-19 22:34:33 +01:00
hash_set_destroy(hash_set);
2022-11-19 17:34:56 +01:00
return EXIT_SUCCESS;
}