aboutsummaryrefslogtreecommitdiff
path: root/lib
diff options
context:
space:
mode:
authorDavid Oberhollenzer <david.oberhollenzer@sigma-star.at>2023-05-14 03:37:36 +0200
committerDavid Oberhollenzer <david.oberhollenzer@sigma-star.at>2023-05-14 03:38:00 +0200
commit7d01bbb78c11cb54c96cf9708916a116190364cb (patch)
tree93ed0294338d3fca7826b1ec9280c56a7ffda66b /lib
parent5e96ce975e021551006ebff744c104f20d49741b (diff)
libio: Move skip function into dir_iterator_t base interface
For regular iterator types, it's a no-op, for the tree iterator, it skips the sub tree. Signed-off-by: David Oberhollenzer <david.oberhollenzer@sigma-star.at>
Diffstat (limited to 'lib')
-rw-r--r--lib/io/src/dir_tree_iterator.c15
-rw-r--r--lib/io/src/unix/dir_iterator.c7
-rw-r--r--lib/io/src/win32/dir_iterator.c7
-rw-r--r--lib/io/test/dir_tree_iterator.c4
4 files changed, 24 insertions, 9 deletions
diff --git a/lib/io/src/dir_tree_iterator.c b/lib/io/src/dir_tree_iterator.c
index 85b1c9f..604efd5 100644
--- a/lib/io/src/dir_tree_iterator.c
+++ b/lib/io/src/dir_tree_iterator.c
@@ -265,6 +265,13 @@ static int open_subdir(dir_iterator_t *base, dir_iterator_t **out)
return it->top->dir->open_subdir(it->top->dir, out);
}
+static void ignore_subdir(dir_iterator_t *base)
+{
+ dir_tree_iterator_t *it = (dir_tree_iterator_t *)base;
+
+ pop(it);
+}
+
dir_iterator_t *dir_tree_iterator_create(const char *path,
const dir_tree_cfg_t *cfg)
{
@@ -295,16 +302,10 @@ dir_iterator_t *dir_tree_iterator_create(const char *path,
((dir_iterator_t *)it)->next = next;
((dir_iterator_t *)it)->read_link = read_link;
((dir_iterator_t *)it)->open_subdir = open_subdir;
+ ((dir_iterator_t *)it)->ignore_subdir = ignore_subdir;
return (dir_iterator_t *)it;
fail:
free(it);
return NULL;
}
-
-void dir_tree_iterator_skip(dir_iterator_t *base)
-{
- dir_tree_iterator_t *it = (dir_tree_iterator_t *)base;
-
- pop(it);
-}
diff --git a/lib/io/src/unix/dir_iterator.c b/lib/io/src/unix/dir_iterator.c
index d67fe83..d2727ad 100644
--- a/lib/io/src/unix/dir_iterator.c
+++ b/lib/io/src/unix/dir_iterator.c
@@ -121,6 +121,11 @@ static int dir_next(dir_iterator_t *base, dir_entry_t **out)
return it->state;
}
+static void dir_ignore_subdir(dir_iterator_t *it)
+{
+ (void)it;
+}
+
static int dir_open_subdir(dir_iterator_t *base, dir_iterator_t **out)
{
const unix_dir_iterator_t *it = (const unix_dir_iterator_t *)base;
@@ -160,6 +165,7 @@ static int dir_open_subdir(dir_iterator_t *base, dir_iterator_t **out)
((dir_iterator_t *)sub)->next = dir_next;
((dir_iterator_t *)sub)->read_link = dir_read_link;
((dir_iterator_t *)sub)->open_subdir = dir_open_subdir;
+ ((dir_iterator_t *)sub)->ignore_subdir = dir_ignore_subdir;
*out = (dir_iterator_t *)sub;
return 0;
@@ -199,6 +205,7 @@ dir_iterator_t *dir_iterator_create(const char *path)
((dir_iterator_t *)it)->next = dir_next;
((dir_iterator_t *)it)->read_link = dir_read_link;
((dir_iterator_t *)it)->open_subdir = dir_open_subdir;
+ ((dir_iterator_t *)it)->ignore_subdir = dir_ignore_subdir;
return (dir_iterator_t *)it;
}
diff --git a/lib/io/src/win32/dir_iterator.c b/lib/io/src/win32/dir_iterator.c
index 23d00f4..94fd6e6 100644
--- a/lib/io/src/win32/dir_iterator.c
+++ b/lib/io/src/win32/dir_iterator.c
@@ -107,6 +107,11 @@ static void dir_iterator_destroy(sqfs_object_t *obj)
free(dir);
}
+static void dir_iterator_ignore_subdir(dir_iterator_t *it)
+{
+ (void)it;
+}
+
static int dir_iterator_open_subdir(dir_iterator_t *it, dir_iterator_t **out)
{
const dir_iterator_win32_t *dir = (const dir_iterator_win32_t *)it;
@@ -139,6 +144,7 @@ static int dir_iterator_open_subdir(dir_iterator_t *it, dir_iterator_t **out)
((dir_iterator_t *)sub)->next = dir_iterator_next;
((dir_iterator_t *)sub)->read_link = dir_iterator_read_link;
((dir_iterator_t *)sub)->open_subdir = dir_iterator_open_subdir;
+ ((dir_iterator_t *)sub)->ignore_subdir = dir_iterator_ignore_subdir;
sub->is_first = true;
sub->state = 0;
@@ -198,6 +204,7 @@ dir_iterator_t *dir_iterator_create(const char *path)
((dir_iterator_t *)it)->next = dir_iterator_next;
((dir_iterator_t *)it)->read_link = dir_iterator_read_link;
((dir_iterator_t *)it)->open_subdir = dir_iterator_open_subdir;
+ ((dir_iterator_t *)it)->ignore_subdir = dir_iterator_ignore_subdir;
it->is_first = true;
it->state = 0;
diff --git a/lib/io/test/dir_tree_iterator.c b/lib/io/test/dir_tree_iterator.c
index 46e0a56..0c735e2 100644
--- a/lib/io/test/dir_tree_iterator.c
+++ b/lib/io/test/dir_tree_iterator.c
@@ -152,7 +152,7 @@ int main(int argc, char **argv)
printf("READ %s\n", ent[i]->name);
if (!strcmp(ent[i]->name, "dirb/dirx"))
- dir_tree_iterator_skip(dir);
+ dir->ignore_subdir(dir);
}
ret = dir->next(dir, &ent[13]);
@@ -210,7 +210,7 @@ int main(int argc, char **argv)
printf("READ %s\n", ent[i]->name);
if (!strcmp(ent[i]->name, "dirb"))
- dir_tree_iterator_skip(dir);
+ dir->ignore_subdir(dir);
}
ret = dir->next(dir, &ent[9]);