X-Git-Url: http://www.chiark.greenend.org.uk/ucgi/~ianmdlvl/git?a=blobdiff_plain;f=src%2Fbasic%2Ffs-util.h;h=60f465a4d919bf2a301bdd66c916c6994b732a29;hb=c0e8baacdbcf4cee407eb0c50c6fbb7e4e089158;hp=de4bb861eab7ea574ba5713b6003f6b37473e2e7;hpb=2f30582bd3d00ce582d190ddb379e46e0a67f813;p=elogind.git diff --git a/src/basic/fs-util.h b/src/basic/fs-util.h index de4bb861e..60f465a4d 100644 --- a/src/basic/fs-util.h +++ b/src/basic/fs-util.h @@ -90,5 +90,23 @@ union inotify_event_buffer { int inotify_add_watch_fd(int fd, int what, uint32_t mask); -int chase_symlinks(const char *path, const char *_root, char **ret); #endif // 0 +enum { + CHASE_PREFIX_ROOT = 1, /* If set, the specified path will be prefixed by the specified root before beginning the iteration */ + CHASE_NONEXISTENT = 2, /* If set, it's OK if the path doesn't actually exist. */ +}; + +int chase_symlinks(const char *path_with_prefix, const char *root, unsigned flags, char **ret); + +/* Useful for usage with _cleanup_(), removes a directory and frees the pointer */ +static inline void rmdir_and_free(char *p) { + (void) rmdir(p); + free(p); +} +DEFINE_TRIVIAL_CLEANUP_FUNC(char*, rmdir_and_free); + +static inline void unlink_and_free(char *p) { + (void) unlink(p); + free(p); +} +DEFINE_TRIVIAL_CLEANUP_FUNC(char*, unlink_and_free);