diff options
author | midipix <writeonce@midipix.org> | 2024-05-27 01:19:40 +0000 |
---|---|---|
committer | midipix <writeonce@midipix.org> | 2024-05-27 01:30:14 +0000 |
commit | cf351e2ca821a190e2dbe25875fea29168b92f72 (patch) | |
tree | 72d768dc5510a851b72c1b6571f43e974bed31cc /src | |
parent | 86604c6822f05f62aaf2cd4d9275f53e6ac9a70c (diff) | |
download | tpax-cf351e2ca821a190e2dbe25875fea29168b92f72.tar.bz2 tpax-cf351e2ca821a190e2dbe25875fea29168b92f72.tar.xz |
core api: implemented tpax_archive_reset().
Diffstat (limited to 'src')
-rw-r--r-- | src/logic/tpax_archive_reset.c | 59 |
1 files changed, 59 insertions, 0 deletions
diff --git a/src/logic/tpax_archive_reset.c b/src/logic/tpax_archive_reset.c new file mode 100644 index 0000000..52a9008 --- /dev/null +++ b/src/logic/tpax_archive_reset.c @@ -0,0 +1,59 @@ +/**************************************************************/ +/* tpax: a topological pax implementation */ +/* Copyright (C) 2020--2024 SysDeer Technologies, LLC */ +/* Released under GPLv2 and GPLv3; see COPYING.TPAX. */ +/**************************************************************/ + +#include <stdint.h> +#include <stdlib.h> +#include <sys/mman.h> + +#include <tpax/tpax.h> +#include "tpax_driver_impl.h" + +/**********************************************/ +/* release and reset the following objects: */ +/* */ +/* - item queue */ +/* - queue vector */ +/* - cached prefixes */ +/* - prefix vector */ +/* */ +/**********************************************/ + +int tpax_archive_reset(const struct tpax_driver_ctx * dctx) +{ + struct tpax_driver_ctx_impl * ictx; + void * next; + size_t size; + char ** ppref; + + ictx = tpax_get_driver_ictx(dctx); + + for (; ictx->dirents; ) { + next = ictx->dirents->next; + size = ictx->dirents->size; + + munmap(ictx->dirents,size); + ictx->dirents = (struct tpax_dirent_buffer *)next; + } + + for (ppref=ictx->prefixv; *ppref; ppref++) + free(*ppref); + + for (ppref=ictx->prefptr; ppref<ictx->prefcap; ppref++) + *ppref = 0; + + if (ictx->prefixv != ictx->prefptr) + free(ictx->prefixv); + + if (ictx->direntv) + free(ictx->direntv); + + ictx->nqueued = 0; + ictx->dirents = 0; + ictx->direntv = 0; + ictx->prefixv = ictx->prefptr; + + return 0; +} |