diff options
author | David Oberhollenzer <david.oberhollenzer@sigma-star.at> | 2023-07-13 20:11:10 +0200 |
---|---|---|
committer | David Oberhollenzer <david.oberhollenzer@sigma-star.at> | 2023-08-10 09:26:59 +0200 |
commit | b79fa32baf127c30d386888c3830129e132a855d (patch) | |
tree | 69ccf1a90c211ba2da134f23657bcd21586d65e5 /lib/io/src/win32 | |
parent | e16f993bba70e7541a32f0e3e7080d2ab3aeb762 (diff) |
libio: dir iterator: merge common code paths for initialization
Signed-off-by: David Oberhollenzer <david.oberhollenzer@sigma-star.at>
Diffstat (limited to 'lib/io/src/win32')
-rw-r--r-- | lib/io/src/win32/dir_iterator.c | 57 |
1 files changed, 28 insertions, 29 deletions
diff --git a/lib/io/src/win32/dir_iterator.c b/lib/io/src/win32/dir_iterator.c index b7a47b9..d9e5b7c 100644 --- a/lib/io/src/win32/dir_iterator.c +++ b/lib/io/src/win32/dir_iterator.c @@ -133,11 +133,14 @@ static int dir_iterator_read_xattr(dir_iterator_t *it, sqfs_xattr_t **out) return 0; } +static int dir_iterator_init(dir_iterator_win32_t *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; dir_iterator_win32_t *sub = NULL; size_t plen, slen, total; + int ret; *out = NULL; @@ -161,23 +164,33 @@ static int dir_iterator_open_subdir(dir_iterator_t *it, dir_iterator_t **out) sub->path[plen + slen + 1] = '*'; sub->path[plen + slen + 2] = '\0'; - sqfs_object_init(sub, dir_iterator_destroy, NULL); - ((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; - ((dir_iterator_t *)sub)->open_file_ro = dir_iterator_open_file_ro; - ((dir_iterator_t *)sub)->read_xattr = dir_iterator_read_xattr; - sub->is_first = true; - sub->state = 0; - - sub->dirhnd = FindFirstFileW(sub->path, &sub->ent); - if (sub->dirhnd == INVALID_HANDLE_VALUE) { + ret = dir_iterator_init(sub); + if (ret != 0) { free(sub); - return SQFS_ERROR_IO; + sub = NULL; } *out = (dir_iterator_t *)sub; + return ret; +} + +static int dir_iterator_init(dir_iterator_win32_t *it) +{ + sqfs_object_init(it, dir_iterator_destroy, NULL); + + ((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; + ((dir_iterator_t *)it)->open_file_ro = dir_iterator_open_file_ro; + ((dir_iterator_t *)it)->read_xattr = dir_iterator_read_xattr; + it->is_first = true; + it->state = 0; + + it->dirhnd = FindFirstFileW(it->path, &it->ent); + if (it->dirhnd == INVALID_HANDLE_VALUE) + return SQFS_ERROR_IO; + return 0; } @@ -222,24 +235,10 @@ dir_iterator_t *dir_iterator_create(const char *path) /* initialize */ memset(it, 0, offsetof(dir_iterator_win32_t, path)); - sqfs_object_init(it, dir_iterator_destroy, NULL); - - ((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; - ((dir_iterator_t *)it)->open_file_ro = dir_iterator_open_file_ro; - ((dir_iterator_t *)it)->read_xattr = dir_iterator_read_xattr; - it->is_first = true; - it->state = 0; - - /* get the directory handle AND the first entry */ - it->dirhnd = FindFirstFileW(it->path, &it->ent); - - if (it->dirhnd == INVALID_HANDLE_VALUE) { + if (dir_iterator_init(it) != 0) { w32_perror(path); free(it); - return NULL; + it = NULL; } return (dir_iterator_t *)it; |