2020-11-09 05:23:58 +01:00
|
|
|
/* SPDX-License-Identifier: LGPL-2.1-or-later */
|
2015-04-04 11:52:57 +02:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <sys/stat.h>
|
|
|
|
|
2019-03-14 12:24:39 +01:00
|
|
|
#include "errno-util.h"
|
2018-01-10 17:21:15 +01:00
|
|
|
|
2015-04-04 11:52:57 +02:00
|
|
|
typedef enum RemoveFlags {
|
2019-03-29 16:13:03 +01:00
|
|
|
REMOVE_ONLY_DIRECTORIES = 1 << 0, /* Only remove empty directories, no files */
|
|
|
|
REMOVE_ROOT = 1 << 1, /* Remove the specified directory itself too, not just the contents of it */
|
|
|
|
REMOVE_PHYSICAL = 1 << 2, /* If not set, only removes files on tmpfs, never physical file systems */
|
|
|
|
REMOVE_SUBVOLUME = 1 << 3, /* Drop btrfs subvolumes in the tree too */
|
|
|
|
REMOVE_MISSING_OK = 1 << 4, /* If the top-level directory is missing, ignore the ENOENT for it */
|
2020-07-23 15:24:54 +02:00
|
|
|
REMOVE_CHMOD = 1 << 5, /* chmod() for write access if we cannot delete something */
|
2015-04-04 11:52:57 +02:00
|
|
|
} RemoveFlags;
|
|
|
|
|
|
|
|
int rm_rf_children(int fd, RemoveFlags flags, struct stat *root_dev);
|
|
|
|
int rm_rf(const char *path, RemoveFlags flags);
|
2016-04-08 18:54:05 +02:00
|
|
|
|
|
|
|
/* Useful for usage with _cleanup_(), destroys a directory and frees the pointer */
|
2016-05-20 15:08:24 +02:00
|
|
|
static inline void rm_rf_physical_and_free(char *p) {
|
2018-01-10 17:21:15 +01:00
|
|
|
PROTECT_ERRNO;
|
2016-05-20 15:08:24 +02:00
|
|
|
(void) rm_rf(p, REMOVE_ROOT|REMOVE_PHYSICAL);
|
2016-04-08 18:54:05 +02:00
|
|
|
free(p);
|
|
|
|
}
|
2016-05-20 15:08:24 +02:00
|
|
|
DEFINE_TRIVIAL_CLEANUP_FUNC(char*, rm_rf_physical_and_free);
|
2018-10-10 21:20:08 +02:00
|
|
|
|
|
|
|
/* Similar as above, but also has magic btrfs subvolume powers */
|
|
|
|
static inline void rm_rf_subvolume_and_free(char *p) {
|
|
|
|
PROTECT_ERRNO;
|
|
|
|
(void) rm_rf(p, REMOVE_ROOT|REMOVE_PHYSICAL|REMOVE_SUBVOLUME);
|
|
|
|
free(p);
|
|
|
|
}
|
|
|
|
DEFINE_TRIVIAL_CLEANUP_FUNC(char*, rm_rf_subvolume_and_free);
|