From 11e36726f61e8615bb873c2d322d85dafcd73e7b Mon Sep 17 00:00:00 2001 From: David Oberhollenzer Date: Fri, 28 Apr 2023 12:22:18 +0200 Subject: Move type based filtering to libutil dir_tree_iterator_t Limited unit testing for the flags is added, particularly the abillity to recurse into sub-directories, but not report the parents as individual entries. Signed-off-by: David Oberhollenzer --- bin/gensquashfs/src/fstree_from_dir.c | 45 +++++------------------------------ bin/gensquashfs/src/mkfs.h | 16 ------------- 2 files changed, 6 insertions(+), 55 deletions(-) (limited to 'bin/gensquashfs') diff --git a/bin/gensquashfs/src/fstree_from_dir.c b/bin/gensquashfs/src/fstree_from_dir.c index 9241428..4c6a828 100644 --- a/bin/gensquashfs/src/fstree_from_dir.c +++ b/bin/gensquashfs/src/fstree_from_dir.c @@ -12,32 +12,6 @@ #include #include -static bool should_skip(const dir_iterator_t *dir, const dir_entry_t *ent, - unsigned int flags) -{ - if ((flags & DIR_SCAN_ONE_FILESYSTEM) && ent->dev != dir->dev) - return true; - - switch (ent->mode & S_IFMT) { - case S_IFSOCK: - return (flags & DIR_SCAN_NO_SOCK) != 0; - case S_IFLNK: - return (flags & DIR_SCAN_NO_SLINK) != 0; - case S_IFREG: - return (flags & DIR_SCAN_NO_FILE) != 0; - case S_IFBLK: - return (flags & DIR_SCAN_NO_BLK) != 0; - case S_IFCHR: - return (flags & DIR_SCAN_NO_CHR) != 0; - case S_IFIFO: - return (flags & DIR_SCAN_NO_FIFO) != 0; - default: - break; - } - - return false; -} - static sqfs_u32 clamp_timestamp(sqfs_s64 ts) { if (ts < 0) @@ -82,11 +56,6 @@ static int scan_dir(fstree_t *fs, tree_node_t *root, dir_iterator_t *dir, return -1; } - if (should_skip(dir, ent, flags)) { - free(ent); - continue; - } - if (S_ISLNK(ent->mode)) { ret = dir->read_link(dir, &extra); if (ret) { @@ -96,9 +65,6 @@ static int scan_dir(fstree_t *fs, tree_node_t *root, dir_iterator_t *dir, } } - if (!(flags & DIR_SCAN_KEEP_TIME)) - ent->mtime = fs->defaults.mtime; - if (S_ISDIR(ent->mode) && (flags & DIR_SCAN_NO_DIR)) { n = fstree_get_node_by_path(fs, root, ent->name, false, false); @@ -140,11 +106,7 @@ static int scan_dir(fstree_t *fs, tree_node_t *root, dir_iterator_t *dir, if (S_ISDIR(n->mode)) dir_tree_iterator_skip(dir); discard_node(n->parent, n); - continue; } - - if ((flags & DIR_SCAN_NO_RECURSION) && S_ISDIR(n->mode)) - dir_tree_iterator_skip(dir); } return 0; @@ -156,6 +118,7 @@ int fstree_from_subdir(fstree_t *fs, tree_node_t *root, unsigned int flags) { dir_iterator_t *dir; + dir_tree_cfg_t cfg; size_t plen, slen; char *temp = NULL; int ret; @@ -186,7 +149,11 @@ int fstree_from_subdir(fstree_t *fs, tree_node_t *root, path = temp; } - dir = dir_tree_iterator_create(path); + memset(&cfg, 0, sizeof(cfg)); + cfg.flags = flags & ~(DIR_SCAN_NO_DIR); + cfg.def_mtime = fs->defaults.mtime; + + dir = dir_tree_iterator_create(path, &cfg); free(temp); if (dir == NULL) return -1; diff --git a/bin/gensquashfs/src/mkfs.h b/bin/gensquashfs/src/mkfs.h index 28bcfde..a58365d 100644 --- a/bin/gensquashfs/src/mkfs.h +++ b/bin/gensquashfs/src/mkfs.h @@ -42,22 +42,6 @@ #include #include -enum { - DIR_SCAN_KEEP_TIME = 0x01, - - DIR_SCAN_ONE_FILESYSTEM = 0x02, - - DIR_SCAN_NO_RECURSION = 0x04, - - DIR_SCAN_NO_SOCK = 0x0008, - DIR_SCAN_NO_SLINK = 0x0010, - DIR_SCAN_NO_FILE = 0x0020, - DIR_SCAN_NO_BLK = 0x0040, - DIR_SCAN_NO_DIR = 0x0080, - DIR_SCAN_NO_CHR = 0x0100, - DIR_SCAN_NO_FIFO = 0x0200, -}; - /* Optionally used by fstree_from_dir and fstree_from_subdir to execute custom actions for each discovered node. -- cgit v1.2.3