diff options
author | David Oberhollenzer <david.oberhollenzer@sigma-star.at> | 2022-06-01 11:46:11 +0200 |
---|---|---|
committer | David Oberhollenzer <david.oberhollenzer@sigma-star.at> | 2022-06-02 17:26:53 +0200 |
commit | 653e24411937f9200ddfae9080f904a1d16d3366 (patch) | |
tree | 52279479c6f8487d0ab5b784d6d5702594a8fbc2 /lib/sqfs/dir_reader/dcache.c | |
parent | a36cf2824c74a3ba7333801268d0ba4194684423 (diff) |
Cleanup: libsqfs: merge dir cache code back into dir_reader.c
Signed-off-by: David Oberhollenzer <david.oberhollenzer@sigma-star.at>
Diffstat (limited to 'lib/sqfs/dir_reader/dcache.c')
-rw-r--r-- | lib/sqfs/dir_reader/dcache.c | 73 |
1 files changed, 0 insertions, 73 deletions
diff --git a/lib/sqfs/dir_reader/dcache.c b/lib/sqfs/dir_reader/dcache.c deleted file mode 100644 index 47fbf73..0000000 --- a/lib/sqfs/dir_reader/dcache.c +++ /dev/null @@ -1,73 +0,0 @@ -/* SPDX-License-Identifier: LGPL-3.0-or-later */ -/* - * dcache.c - * - * Copyright (C) 2019 David Oberhollenzer <goliath@infraroot.at> - */ -#define SQFS_BUILDING_DLL -#include "internal.h" - -static int dcache_key_compare(const void *ctx, const void *l, const void *r) -{ - sqfs_u32 lhs = *((const sqfs_u32 *)l), rhs = *((const sqfs_u32 *)r); - (void)ctx; - - return lhs < rhs ? -1 : (lhs > rhs ? 1 : 0); -} - -int sqfs_dir_reader_dcache_init(sqfs_dir_reader_t *rd, sqfs_u32 flags) -{ - if (!(flags & SQFS_DIR_READER_DOT_ENTRIES)) - return 0; - - return rbtree_init(&rd->dcache, sizeof(sqfs_u32), sizeof(sqfs_u64), - dcache_key_compare); -} - -int sqfs_dir_reader_dcache_init_copy(sqfs_dir_reader_t *copy, - const sqfs_dir_reader_t *rd) -{ - if (!(rd->flags & SQFS_DIR_READER_DOT_ENTRIES)) - return 0; - - return rbtree_copy(&rd->dcache, ©->dcache); -} - -void sqfs_dir_reader_dcache_cleanup(sqfs_dir_reader_t *rd) -{ - if (!(rd->flags & SQFS_DIR_READER_DOT_ENTRIES)) - return; - - rbtree_cleanup(&rd->dcache); -} - -int sqfs_dir_reader_dcache_add(sqfs_dir_reader_t *rd, - sqfs_u32 inode, sqfs_u64 ref) -{ - rbtree_node_t *node; - - if (!(rd->flags & SQFS_DIR_READER_DOT_ENTRIES)) - return 0; - - node = rbtree_lookup(&rd->dcache, &inode); - if (node != NULL) - return 0; - - return rbtree_insert(&rd->dcache, &inode, &ref); -} - -int sqfs_dir_reader_dcache_find(sqfs_dir_reader_t *rd, - sqfs_u32 inode, sqfs_u64 *ref) -{ - rbtree_node_t *node; - - if (!(rd->flags & SQFS_DIR_READER_DOT_ENTRIES)) - return SQFS_ERROR_NO_ENTRY; - - node = rbtree_lookup(&rd->dcache, &inode); - if (node == NULL) - return SQFS_ERROR_NO_ENTRY; - - *ref = *((sqfs_u64 *)rbtree_node_value(node)); - return 0; -} |