dpkg 1.21.11
treewalk.h
Go to the documentation of this file.
1/*
2 * libdpkg - Debian packaging suite library routines
3 * treewalk.h - directory tree walk support
4 *
5 * Copyright © 2013-2015 Guillem Jover <guillem@debian.org>
6 *
7 * This is free software; you can redistribute it and/or modify
8 * it under the terms of the GNU General Public License as published by
9 * the Free Software Foundation; either version 2 of the License, or
10 * (at your option) any later version.
11 *
12 * This is distributed in the hope that it will be useful,
13 * but WITHOUT ANY WARRANTY; without even the implied warranty of
14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15 * GNU General Public License for more details.
16 *
17 * You should have received a copy of the GNU General Public License
18 * along with this program. If not, see <https://www.gnu.org/licenses/>.
19 */
20
21#ifndef LIBDPKG_TREEWALK_H
22#define LIBDPKG_TREEWALK_H
23
24#include <dpkg/macros.h>
25
26#include <sys/stat.h>
27#include <sys/types.h>
28
29#include <stdbool.h>
30
32
43};
44
45struct treenode;
46
47typedef int treenode_visit_func(struct treenode *node);
48typedef bool treenode_skip_func(struct treenode *node);
49typedef int treenode_sort_func(struct treenode *node);
50
55};
56
57struct treeroot *
58treewalk_open(const char *rootdir, enum treewalk_options options,
59 const struct treewalk_funcs *funcs);
60struct treenode *
61treewalk_node(struct treeroot *tree);
62struct treenode *
63treewalk_next(struct treeroot *tree);
64void
65treewalk_close(struct treeroot *tree);
66
67int
68treewalk(const char *rootdir, enum treewalk_options options,
69 struct treewalk_funcs *funcs);
70
71struct treenode *
72treenode_get_parent(struct treenode *node);
73const char *
74treenode_get_name(struct treenode *node);
75const char *
77const char *
79mode_t
80treenode_get_mode(struct treenode *node);
81struct stat *
82treenode_get_stat(struct treenode *node);
83
87
88#endif /* LIBDPKG_TREEWALK_H */
#define DPKG_BEGIN_DECLS
Definition: macros.h:86
#define DPKG_END_DECLS
Definition: macros.h:87
#define DPKG_BIT(n)
Return the integer value of bit n.
Definition: macros.h:125
const char * treenode_get_name(struct treenode *node)
Definition: treewalk.c:155
const char * treenode_get_virtname(struct treenode *node)
Definition: treewalk.c:167
const char * treenode_get_pathname(struct treenode *node)
Definition: treewalk.c:161
int treenode_visit_func(struct treenode *node)
Definition: treewalk.h:47
treewalk_options
Definition: treewalk.h:39
struct stat * treenode_get_stat(struct treenode *node)
Definition: treewalk.c:179
int treewalk(const char *rootdir, enum treewalk_options options, struct treewalk_funcs *funcs)
Tree walker.
Definition: treewalk.c:527
struct treeroot * treewalk_open(const char *rootdir, enum treewalk_options options, const struct treewalk_funcs *funcs)
Open a new tree to be walked.
Definition: treewalk.c:365
struct treenode * treenode_get_parent(struct treenode *node)
Definition: treewalk.c:186
void treewalk_close(struct treeroot *tree)
Closes the tree being walked.
Definition: treewalk.c:514
int treenode_sort_func(struct treenode *node)
Definition: treewalk.h:49
struct treenode * treewalk_node(struct treeroot *tree)
Return the current node.
Definition: treewalk.c:410
bool treenode_skip_func(struct treenode *node)
Definition: treewalk.h:48
mode_t treenode_get_mode(struct treenode *node)
Definition: treewalk.c:173
struct treenode * treewalk_next(struct treeroot *tree)
Return the next node.
Definition: treewalk.c:436
@ TREEWALK_FOLLOW_LINKS
Definition: treewalk.h:42
@ TREEWALK_NONE
Definition: treewalk.h:40
@ TREEWALK_FORCE_STAT
Definition: treewalk.h:41
Definition: treewalk.c:40
Definition: treewalk.c:297
enum treewalk_options options
Definition: treewalk.c:303
Definition: treewalk.h:51
treenode_sort_func * sort
Definition: treewalk.h:53
treenode_visit_func * visit
Definition: treewalk.h:52
treenode_skip_func * skip
Definition: treewalk.h:54