util-lib: move a number of fs operations into fs-util.[ch]
This commit is contained in:
parent
c8b3094de5
commit
f4f15635ec
|
@ -799,6 +799,8 @@ libbasic_la_SOURCES = \
|
||||||
src/basic/xattr-util.h \
|
src/basic/xattr-util.h \
|
||||||
src/basic/chattr-util.c \
|
src/basic/chattr-util.c \
|
||||||
src/basic/chattr-util.h \
|
src/basic/chattr-util.h \
|
||||||
|
src/basic/fs-util.c \
|
||||||
|
src/basic/fs-util.h \
|
||||||
src/basic/mount-util.c \
|
src/basic/mount-util.c \
|
||||||
src/basic/mount-util.h \
|
src/basic/mount-util.h \
|
||||||
src/basic/hexdecoct.c \
|
src/basic/hexdecoct.c \
|
||||||
|
|
|
@ -35,6 +35,7 @@
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
#include "fileio.h"
|
#include "fileio.h"
|
||||||
#include "formats-util.h"
|
#include "formats-util.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "login-util.h"
|
#include "login-util.h"
|
||||||
#include "macro.h"
|
#include "macro.h"
|
||||||
#include "mkdir.h"
|
#include "mkdir.h"
|
||||||
|
|
|
@ -28,6 +28,7 @@
|
||||||
#include "dirent-util.h"
|
#include "dirent-util.h"
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
#include "fileio.h"
|
#include "fileio.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "io-util.h"
|
#include "io-util.h"
|
||||||
#include "string-util.h"
|
#include "string-util.h"
|
||||||
#include "strv.h"
|
#include "strv.h"
|
||||||
|
|
|
@ -25,6 +25,7 @@
|
||||||
#include "escape.h"
|
#include "escape.h"
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
#include "fileio.h"
|
#include "fileio.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "hexdecoct.h"
|
#include "hexdecoct.h"
|
||||||
#include "path-util.h"
|
#include "path-util.h"
|
||||||
#include "random-util.h"
|
#include "random-util.h"
|
||||||
|
|
|
@ -0,0 +1,477 @@
|
||||||
|
/*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/
|
||||||
|
|
||||||
|
/***
|
||||||
|
This file is part of systemd.
|
||||||
|
|
||||||
|
Copyright 2010 Lennart Poettering
|
||||||
|
|
||||||
|
systemd is free software; you can redistribute it and/or modify it
|
||||||
|
under the terms of the GNU Lesser General Public License as published by
|
||||||
|
the Free Software Foundation; either version 2.1 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
systemd is distributed in the hope that it will be useful, but
|
||||||
|
WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Lesser General Public License
|
||||||
|
along with systemd; If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
***/
|
||||||
|
|
||||||
|
#include "dirent-util.h"
|
||||||
|
#include "fd-util.h"
|
||||||
|
#include "fileio.h"
|
||||||
|
#include "fs-util.h"
|
||||||
|
#include "mkdir.h"
|
||||||
|
#include "path-util.h"
|
||||||
|
#include "string-util.h"
|
||||||
|
#include "strv.h"
|
||||||
|
#include "util.h"
|
||||||
|
|
||||||
|
int unlink_noerrno(const char *path) {
|
||||||
|
PROTECT_ERRNO;
|
||||||
|
int r;
|
||||||
|
|
||||||
|
r = unlink(path);
|
||||||
|
if (r < 0)
|
||||||
|
return -errno;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int rmdir_parents(const char *path, const char *stop) {
|
||||||
|
size_t l;
|
||||||
|
int r = 0;
|
||||||
|
|
||||||
|
assert(path);
|
||||||
|
assert(stop);
|
||||||
|
|
||||||
|
l = strlen(path);
|
||||||
|
|
||||||
|
/* Skip trailing slashes */
|
||||||
|
while (l > 0 && path[l-1] == '/')
|
||||||
|
l--;
|
||||||
|
|
||||||
|
while (l > 0) {
|
||||||
|
char *t;
|
||||||
|
|
||||||
|
/* Skip last component */
|
||||||
|
while (l > 0 && path[l-1] != '/')
|
||||||
|
l--;
|
||||||
|
|
||||||
|
/* Skip trailing slashes */
|
||||||
|
while (l > 0 && path[l-1] == '/')
|
||||||
|
l--;
|
||||||
|
|
||||||
|
if (l <= 0)
|
||||||
|
break;
|
||||||
|
|
||||||
|
t = strndup(path, l);
|
||||||
|
if (!t)
|
||||||
|
return -ENOMEM;
|
||||||
|
|
||||||
|
if (path_startswith(stop, t)) {
|
||||||
|
free(t);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
r = rmdir(t);
|
||||||
|
free(t);
|
||||||
|
|
||||||
|
if (r < 0)
|
||||||
|
if (errno != ENOENT)
|
||||||
|
return -errno;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
int rename_noreplace(int olddirfd, const char *oldpath, int newdirfd, const char *newpath) {
|
||||||
|
struct stat buf;
|
||||||
|
int ret;
|
||||||
|
|
||||||
|
ret = renameat2(olddirfd, oldpath, newdirfd, newpath, RENAME_NOREPLACE);
|
||||||
|
if (ret >= 0)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
/* renameat2() exists since Linux 3.15, btrfs added support for it later.
|
||||||
|
* If it is not implemented, fallback to another method. */
|
||||||
|
if (!IN_SET(errno, EINVAL, ENOSYS))
|
||||||
|
return -errno;
|
||||||
|
|
||||||
|
/* The link()/unlink() fallback does not work on directories. But
|
||||||
|
* renameat() without RENAME_NOREPLACE gives the same semantics on
|
||||||
|
* directories, except when newpath is an *empty* directory. This is
|
||||||
|
* good enough. */
|
||||||
|
ret = fstatat(olddirfd, oldpath, &buf, AT_SYMLINK_NOFOLLOW);
|
||||||
|
if (ret >= 0 && S_ISDIR(buf.st_mode)) {
|
||||||
|
ret = renameat(olddirfd, oldpath, newdirfd, newpath);
|
||||||
|
return ret >= 0 ? 0 : -errno;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* If it is not a directory, use the link()/unlink() fallback. */
|
||||||
|
ret = linkat(olddirfd, oldpath, newdirfd, newpath, 0);
|
||||||
|
if (ret < 0)
|
||||||
|
return -errno;
|
||||||
|
|
||||||
|
ret = unlinkat(olddirfd, oldpath, 0);
|
||||||
|
if (ret < 0) {
|
||||||
|
/* backup errno before the following unlinkat() alters it */
|
||||||
|
ret = errno;
|
||||||
|
(void) unlinkat(newdirfd, newpath, 0);
|
||||||
|
errno = ret;
|
||||||
|
return -errno;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int readlinkat_malloc(int fd, const char *p, char **ret) {
|
||||||
|
size_t l = 100;
|
||||||
|
int r;
|
||||||
|
|
||||||
|
assert(p);
|
||||||
|
assert(ret);
|
||||||
|
|
||||||
|
for (;;) {
|
||||||
|
char *c;
|
||||||
|
ssize_t n;
|
||||||
|
|
||||||
|
c = new(char, l);
|
||||||
|
if (!c)
|
||||||
|
return -ENOMEM;
|
||||||
|
|
||||||
|
n = readlinkat(fd, p, c, l-1);
|
||||||
|
if (n < 0) {
|
||||||
|
r = -errno;
|
||||||
|
free(c);
|
||||||
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((size_t) n < l-1) {
|
||||||
|
c[n] = 0;
|
||||||
|
*ret = c;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
free(c);
|
||||||
|
l *= 2;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
int readlink_malloc(const char *p, char **ret) {
|
||||||
|
return readlinkat_malloc(AT_FDCWD, p, ret);
|
||||||
|
}
|
||||||
|
|
||||||
|
int readlink_value(const char *p, char **ret) {
|
||||||
|
_cleanup_free_ char *link = NULL;
|
||||||
|
char *value;
|
||||||
|
int r;
|
||||||
|
|
||||||
|
r = readlink_malloc(p, &link);
|
||||||
|
if (r < 0)
|
||||||
|
return r;
|
||||||
|
|
||||||
|
value = basename(link);
|
||||||
|
if (!value)
|
||||||
|
return -ENOENT;
|
||||||
|
|
||||||
|
value = strdup(value);
|
||||||
|
if (!value)
|
||||||
|
return -ENOMEM;
|
||||||
|
|
||||||
|
*ret = value;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int readlink_and_make_absolute(const char *p, char **r) {
|
||||||
|
_cleanup_free_ char *target = NULL;
|
||||||
|
char *k;
|
||||||
|
int j;
|
||||||
|
|
||||||
|
assert(p);
|
||||||
|
assert(r);
|
||||||
|
|
||||||
|
j = readlink_malloc(p, &target);
|
||||||
|
if (j < 0)
|
||||||
|
return j;
|
||||||
|
|
||||||
|
k = file_in_same_dir(p, target);
|
||||||
|
if (!k)
|
||||||
|
return -ENOMEM;
|
||||||
|
|
||||||
|
*r = k;
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int readlink_and_canonicalize(const char *p, char **r) {
|
||||||
|
char *t, *s;
|
||||||
|
int j;
|
||||||
|
|
||||||
|
assert(p);
|
||||||
|
assert(r);
|
||||||
|
|
||||||
|
j = readlink_and_make_absolute(p, &t);
|
||||||
|
if (j < 0)
|
||||||
|
return j;
|
||||||
|
|
||||||
|
s = canonicalize_file_name(t);
|
||||||
|
if (s) {
|
||||||
|
free(t);
|
||||||
|
*r = s;
|
||||||
|
} else
|
||||||
|
*r = t;
|
||||||
|
|
||||||
|
path_kill_slashes(*r);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int chmod_and_chown(const char *path, mode_t mode, uid_t uid, gid_t gid) {
|
||||||
|
assert(path);
|
||||||
|
|
||||||
|
/* Under the assumption that we are running privileged we
|
||||||
|
* first change the access mode and only then hand out
|
||||||
|
* ownership to avoid a window where access is too open. */
|
||||||
|
|
||||||
|
if (mode != MODE_INVALID)
|
||||||
|
if (chmod(path, mode) < 0)
|
||||||
|
return -errno;
|
||||||
|
|
||||||
|
if (uid != UID_INVALID || gid != GID_INVALID)
|
||||||
|
if (chown(path, uid, gid) < 0)
|
||||||
|
return -errno;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int fchmod_and_fchown(int fd, mode_t mode, uid_t uid, gid_t gid) {
|
||||||
|
assert(fd >= 0);
|
||||||
|
|
||||||
|
/* Under the assumption that we are running privileged we
|
||||||
|
* first change the access mode and only then hand out
|
||||||
|
* ownership to avoid a window where access is too open. */
|
||||||
|
|
||||||
|
if (mode != MODE_INVALID)
|
||||||
|
if (fchmod(fd, mode) < 0)
|
||||||
|
return -errno;
|
||||||
|
|
||||||
|
if (uid != UID_INVALID || gid != GID_INVALID)
|
||||||
|
if (fchown(fd, uid, gid) < 0)
|
||||||
|
return -errno;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int fchmod_umask(int fd, mode_t m) {
|
||||||
|
mode_t u;
|
||||||
|
int r;
|
||||||
|
|
||||||
|
u = umask(0777);
|
||||||
|
r = fchmod(fd, m & (~u)) < 0 ? -errno : 0;
|
||||||
|
umask(u);
|
||||||
|
|
||||||
|
return r;
|
||||||
|
}
|
||||||
|
|
||||||
|
int fd_warn_permissions(const char *path, int fd) {
|
||||||
|
struct stat st;
|
||||||
|
|
||||||
|
if (fstat(fd, &st) < 0)
|
||||||
|
return -errno;
|
||||||
|
|
||||||
|
if (st.st_mode & 0111)
|
||||||
|
log_warning("Configuration file %s is marked executable. Please remove executable permission bits. Proceeding anyway.", path);
|
||||||
|
|
||||||
|
if (st.st_mode & 0002)
|
||||||
|
log_warning("Configuration file %s is marked world-writable. Please remove world writability permission bits. Proceeding anyway.", path);
|
||||||
|
|
||||||
|
if (getpid() == 1 && (st.st_mode & 0044) != 0044)
|
||||||
|
log_warning("Configuration file %s is marked world-inaccessible. This has no effect as configuration data is accessible via APIs without restrictions. Proceeding anyway.", path);
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int touch_file(const char *path, bool parents, usec_t stamp, uid_t uid, gid_t gid, mode_t mode) {
|
||||||
|
_cleanup_close_ int fd;
|
||||||
|
int r;
|
||||||
|
|
||||||
|
assert(path);
|
||||||
|
|
||||||
|
if (parents)
|
||||||
|
mkdir_parents(path, 0755);
|
||||||
|
|
||||||
|
fd = open(path, O_WRONLY|O_CREAT|O_CLOEXEC|O_NOCTTY, mode > 0 ? mode : 0644);
|
||||||
|
if (fd < 0)
|
||||||
|
return -errno;
|
||||||
|
|
||||||
|
if (mode > 0) {
|
||||||
|
r = fchmod(fd, mode);
|
||||||
|
if (r < 0)
|
||||||
|
return -errno;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (uid != UID_INVALID || gid != GID_INVALID) {
|
||||||
|
r = fchown(fd, uid, gid);
|
||||||
|
if (r < 0)
|
||||||
|
return -errno;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (stamp != USEC_INFINITY) {
|
||||||
|
struct timespec ts[2];
|
||||||
|
|
||||||
|
timespec_store(&ts[0], stamp);
|
||||||
|
ts[1] = ts[0];
|
||||||
|
r = futimens(fd, ts);
|
||||||
|
} else
|
||||||
|
r = futimens(fd, NULL);
|
||||||
|
if (r < 0)
|
||||||
|
return -errno;
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int touch(const char *path) {
|
||||||
|
return touch_file(path, false, USEC_INFINITY, UID_INVALID, GID_INVALID, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
int symlink_idempotent(const char *from, const char *to) {
|
||||||
|
_cleanup_free_ char *p = NULL;
|
||||||
|
int r;
|
||||||
|
|
||||||
|
assert(from);
|
||||||
|
assert(to);
|
||||||
|
|
||||||
|
if (symlink(from, to) < 0) {
|
||||||
|
if (errno != EEXIST)
|
||||||
|
return -errno;
|
||||||
|
|
||||||
|
r = readlink_malloc(to, &p);
|
||||||
|
if (r < 0)
|
||||||
|
return r;
|
||||||
|
|
||||||
|
if (!streq(p, from))
|
||||||
|
return -EINVAL;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int symlink_atomic(const char *from, const char *to) {
|
||||||
|
_cleanup_free_ char *t = NULL;
|
||||||
|
int r;
|
||||||
|
|
||||||
|
assert(from);
|
||||||
|
assert(to);
|
||||||
|
|
||||||
|
r = tempfn_random(to, NULL, &t);
|
||||||
|
if (r < 0)
|
||||||
|
return r;
|
||||||
|
|
||||||
|
if (symlink(from, t) < 0)
|
||||||
|
return -errno;
|
||||||
|
|
||||||
|
if (rename(t, to) < 0) {
|
||||||
|
unlink_noerrno(t);
|
||||||
|
return -errno;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int mknod_atomic(const char *path, mode_t mode, dev_t dev) {
|
||||||
|
_cleanup_free_ char *t = NULL;
|
||||||
|
int r;
|
||||||
|
|
||||||
|
assert(path);
|
||||||
|
|
||||||
|
r = tempfn_random(path, NULL, &t);
|
||||||
|
if (r < 0)
|
||||||
|
return r;
|
||||||
|
|
||||||
|
if (mknod(t, mode, dev) < 0)
|
||||||
|
return -errno;
|
||||||
|
|
||||||
|
if (rename(t, path) < 0) {
|
||||||
|
unlink_noerrno(t);
|
||||||
|
return -errno;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int mkfifo_atomic(const char *path, mode_t mode) {
|
||||||
|
_cleanup_free_ char *t = NULL;
|
||||||
|
int r;
|
||||||
|
|
||||||
|
assert(path);
|
||||||
|
|
||||||
|
r = tempfn_random(path, NULL, &t);
|
||||||
|
if (r < 0)
|
||||||
|
return r;
|
||||||
|
|
||||||
|
if (mkfifo(t, mode) < 0)
|
||||||
|
return -errno;
|
||||||
|
|
||||||
|
if (rename(t, path) < 0) {
|
||||||
|
unlink_noerrno(t);
|
||||||
|
return -errno;
|
||||||
|
}
|
||||||
|
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int get_files_in_directory(const char *path, char ***list) {
|
||||||
|
_cleanup_closedir_ DIR *d = NULL;
|
||||||
|
size_t bufsize = 0, n = 0;
|
||||||
|
_cleanup_strv_free_ char **l = NULL;
|
||||||
|
|
||||||
|
assert(path);
|
||||||
|
|
||||||
|
/* Returns all files in a directory in *list, and the number
|
||||||
|
* of files as return value. If list is NULL returns only the
|
||||||
|
* number. */
|
||||||
|
|
||||||
|
d = opendir(path);
|
||||||
|
if (!d)
|
||||||
|
return -errno;
|
||||||
|
|
||||||
|
for (;;) {
|
||||||
|
struct dirent *de;
|
||||||
|
|
||||||
|
errno = 0;
|
||||||
|
de = readdir(d);
|
||||||
|
if (!de && errno != 0)
|
||||||
|
return -errno;
|
||||||
|
if (!de)
|
||||||
|
break;
|
||||||
|
|
||||||
|
dirent_ensure_type(d, de);
|
||||||
|
|
||||||
|
if (!dirent_is_file(de))
|
||||||
|
continue;
|
||||||
|
|
||||||
|
if (list) {
|
||||||
|
/* one extra slot is needed for the terminating NULL */
|
||||||
|
if (!GREEDY_REALLOC(l, bufsize, n + 2))
|
||||||
|
return -ENOMEM;
|
||||||
|
|
||||||
|
l[n] = strdup(de->d_name);
|
||||||
|
if (!l[n])
|
||||||
|
return -ENOMEM;
|
||||||
|
|
||||||
|
l[++n] = NULL;
|
||||||
|
} else
|
||||||
|
n++;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (list) {
|
||||||
|
*list = l;
|
||||||
|
l = NULL; /* avoid freeing */
|
||||||
|
}
|
||||||
|
|
||||||
|
return n;
|
||||||
|
}
|
|
@ -0,0 +1,60 @@
|
||||||
|
/*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
/***
|
||||||
|
This file is part of systemd.
|
||||||
|
|
||||||
|
Copyright 2010 Lennart Poettering
|
||||||
|
|
||||||
|
systemd is free software; you can redistribute it and/or modify it
|
||||||
|
under the terms of the GNU Lesser General Public License as published by
|
||||||
|
the Free Software Foundation; either version 2.1 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
systemd is distributed in the hope that it will be useful, but
|
||||||
|
WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
||||||
|
Lesser General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU Lesser General Public License
|
||||||
|
along with systemd; If not, see <http://www.gnu.org/licenses/>.
|
||||||
|
***/
|
||||||
|
|
||||||
|
#include <sys/types.h>
|
||||||
|
#include <fcntl.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
|
||||||
|
#include "time-util.h"
|
||||||
|
|
||||||
|
int unlink_noerrno(const char *path);
|
||||||
|
|
||||||
|
int rmdir_parents(const char *path, const char *stop);
|
||||||
|
|
||||||
|
int rename_noreplace(int olddirfd, const char *oldpath, int newdirfd, const char *newpath);
|
||||||
|
|
||||||
|
int readlinkat_malloc(int fd, const char *p, char **ret);
|
||||||
|
int readlink_malloc(const char *p, char **r);
|
||||||
|
int readlink_value(const char *p, char **ret);
|
||||||
|
int readlink_and_make_absolute(const char *p, char **r);
|
||||||
|
int readlink_and_canonicalize(const char *p, char **r);
|
||||||
|
|
||||||
|
int chmod_and_chown(const char *path, mode_t mode, uid_t uid, gid_t gid);
|
||||||
|
int fchmod_and_fchown(int fd, mode_t mode, uid_t uid, gid_t gid);
|
||||||
|
|
||||||
|
int fchmod_umask(int fd, mode_t mode);
|
||||||
|
|
||||||
|
int fd_warn_permissions(const char *path, int fd);
|
||||||
|
|
||||||
|
#define laccess(path, mode) faccessat(AT_FDCWD, (path), (mode), AT_SYMLINK_NOFOLLOW)
|
||||||
|
|
||||||
|
int touch_file(const char *path, bool parents, usec_t stamp, uid_t uid, gid_t gid, mode_t mode);
|
||||||
|
int touch(const char *path);
|
||||||
|
|
||||||
|
int symlink_idempotent(const char *from, const char *to);
|
||||||
|
|
||||||
|
int symlink_atomic(const char *from, const char *to);
|
||||||
|
int mknod_atomic(const char *path, mode_t mode, dev_t dev);
|
||||||
|
int mkfifo_atomic(const char *path, mode_t mode);
|
||||||
|
|
||||||
|
int get_files_in_directory(const char *path, char ***list);
|
|
@ -29,6 +29,7 @@
|
||||||
|
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
#include "fileio.h"
|
#include "fileio.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "lockfile-util.h"
|
#include "lockfile-util.h"
|
||||||
#include "path-util.h"
|
#include "path-util.h"
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
|
|
|
@ -22,9 +22,10 @@
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
|
|
||||||
#include "util.h"
|
#include "fs-util.h"
|
||||||
#include "path-util.h"
|
|
||||||
#include "mkdir.h"
|
#include "mkdir.h"
|
||||||
|
#include "path-util.h"
|
||||||
|
#include "util.h"
|
||||||
|
|
||||||
int mkdir_safe_internal(const char *path, mode_t mode, uid_t uid, gid_t gid, mkdir_func_t _mkdir) {
|
int mkdir_safe_internal(const char *path, mode_t mode, uid_t uid, gid_t gid, mkdir_func_t _mkdir) {
|
||||||
struct stat st;
|
struct stat st;
|
||||||
|
|
|
@ -35,6 +35,7 @@
|
||||||
|
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
#include "fileio.h"
|
#include "fileio.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
#include "macro.h"
|
#include "macro.h"
|
||||||
#include "missing.h"
|
#include "missing.h"
|
||||||
|
|
|
@ -31,6 +31,7 @@
|
||||||
#include "escape.h"
|
#include "escape.h"
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
#include "fileio.h"
|
#include "fileio.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
#include "process-util.h"
|
#include "process-util.h"
|
||||||
#include "signal-util.h"
|
#include "signal-util.h"
|
||||||
|
|
|
@ -33,6 +33,7 @@
|
||||||
|
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
#include "fileio.h"
|
#include "fileio.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "io-util.h"
|
#include "io-util.h"
|
||||||
#include "parse-util.h"
|
#include "parse-util.h"
|
||||||
#include "path-util.h"
|
#include "path-util.h"
|
||||||
|
|
|
@ -25,6 +25,7 @@
|
||||||
|
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
#include "fileio.h"
|
#include "fileio.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "path-util.h"
|
#include "path-util.h"
|
||||||
#include "string-util.h"
|
#include "string-util.h"
|
||||||
#include "strv.h"
|
#include "strv.h"
|
||||||
|
|
445
src/basic/util.c
445
src/basic/util.c
|
@ -123,176 +123,6 @@ size_t page_size(void) {
|
||||||
return pgsz;
|
return pgsz;
|
||||||
}
|
}
|
||||||
|
|
||||||
int unlink_noerrno(const char *path) {
|
|
||||||
PROTECT_ERRNO;
|
|
||||||
int r;
|
|
||||||
|
|
||||||
r = unlink(path);
|
|
||||||
if (r < 0)
|
|
||||||
return -errno;
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int fchmod_umask(int fd, mode_t m) {
|
|
||||||
mode_t u;
|
|
||||||
int r;
|
|
||||||
|
|
||||||
u = umask(0777);
|
|
||||||
r = fchmod(fd, m & (~u)) < 0 ? -errno : 0;
|
|
||||||
umask(u);
|
|
||||||
|
|
||||||
return r;
|
|
||||||
}
|
|
||||||
|
|
||||||
int readlinkat_malloc(int fd, const char *p, char **ret) {
|
|
||||||
size_t l = 100;
|
|
||||||
int r;
|
|
||||||
|
|
||||||
assert(p);
|
|
||||||
assert(ret);
|
|
||||||
|
|
||||||
for (;;) {
|
|
||||||
char *c;
|
|
||||||
ssize_t n;
|
|
||||||
|
|
||||||
c = new(char, l);
|
|
||||||
if (!c)
|
|
||||||
return -ENOMEM;
|
|
||||||
|
|
||||||
n = readlinkat(fd, p, c, l-1);
|
|
||||||
if (n < 0) {
|
|
||||||
r = -errno;
|
|
||||||
free(c);
|
|
||||||
return r;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ((size_t) n < l-1) {
|
|
||||||
c[n] = 0;
|
|
||||||
*ret = c;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
free(c);
|
|
||||||
l *= 2;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
int readlink_malloc(const char *p, char **ret) {
|
|
||||||
return readlinkat_malloc(AT_FDCWD, p, ret);
|
|
||||||
}
|
|
||||||
|
|
||||||
int readlink_value(const char *p, char **ret) {
|
|
||||||
_cleanup_free_ char *link = NULL;
|
|
||||||
char *value;
|
|
||||||
int r;
|
|
||||||
|
|
||||||
r = readlink_malloc(p, &link);
|
|
||||||
if (r < 0)
|
|
||||||
return r;
|
|
||||||
|
|
||||||
value = basename(link);
|
|
||||||
if (!value)
|
|
||||||
return -ENOENT;
|
|
||||||
|
|
||||||
value = strdup(value);
|
|
||||||
if (!value)
|
|
||||||
return -ENOMEM;
|
|
||||||
|
|
||||||
*ret = value;
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int readlink_and_make_absolute(const char *p, char **r) {
|
|
||||||
_cleanup_free_ char *target = NULL;
|
|
||||||
char *k;
|
|
||||||
int j;
|
|
||||||
|
|
||||||
assert(p);
|
|
||||||
assert(r);
|
|
||||||
|
|
||||||
j = readlink_malloc(p, &target);
|
|
||||||
if (j < 0)
|
|
||||||
return j;
|
|
||||||
|
|
||||||
k = file_in_same_dir(p, target);
|
|
||||||
if (!k)
|
|
||||||
return -ENOMEM;
|
|
||||||
|
|
||||||
*r = k;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int readlink_and_canonicalize(const char *p, char **r) {
|
|
||||||
char *t, *s;
|
|
||||||
int j;
|
|
||||||
|
|
||||||
assert(p);
|
|
||||||
assert(r);
|
|
||||||
|
|
||||||
j = readlink_and_make_absolute(p, &t);
|
|
||||||
if (j < 0)
|
|
||||||
return j;
|
|
||||||
|
|
||||||
s = canonicalize_file_name(t);
|
|
||||||
if (s) {
|
|
||||||
free(t);
|
|
||||||
*r = s;
|
|
||||||
} else
|
|
||||||
*r = t;
|
|
||||||
|
|
||||||
path_kill_slashes(*r);
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int rmdir_parents(const char *path, const char *stop) {
|
|
||||||
size_t l;
|
|
||||||
int r = 0;
|
|
||||||
|
|
||||||
assert(path);
|
|
||||||
assert(stop);
|
|
||||||
|
|
||||||
l = strlen(path);
|
|
||||||
|
|
||||||
/* Skip trailing slashes */
|
|
||||||
while (l > 0 && path[l-1] == '/')
|
|
||||||
l--;
|
|
||||||
|
|
||||||
while (l > 0) {
|
|
||||||
char *t;
|
|
||||||
|
|
||||||
/* Skip last component */
|
|
||||||
while (l > 0 && path[l-1] != '/')
|
|
||||||
l--;
|
|
||||||
|
|
||||||
/* Skip trailing slashes */
|
|
||||||
while (l > 0 && path[l-1] == '/')
|
|
||||||
l--;
|
|
||||||
|
|
||||||
if (l <= 0)
|
|
||||||
break;
|
|
||||||
|
|
||||||
if (!(t = strndup(path, l)))
|
|
||||||
return -ENOMEM;
|
|
||||||
|
|
||||||
if (path_startswith(stop, t)) {
|
|
||||||
free(t);
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
r = rmdir(t);
|
|
||||||
free(t);
|
|
||||||
|
|
||||||
if (r < 0)
|
|
||||||
if (errno != ENOENT)
|
|
||||||
return -errno;
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool fstype_is_network(const char *fstype) {
|
bool fstype_is_network(const char *fstype) {
|
||||||
static const char table[] =
|
static const char table[] =
|
||||||
"afs\0"
|
"afs\0"
|
||||||
|
@ -401,42 +231,6 @@ int fd_is_temporary_fs(int fd) {
|
||||||
return is_temporary_fs(&s);
|
return is_temporary_fs(&s);
|
||||||
}
|
}
|
||||||
|
|
||||||
int chmod_and_chown(const char *path, mode_t mode, uid_t uid, gid_t gid) {
|
|
||||||
assert(path);
|
|
||||||
|
|
||||||
/* Under the assumption that we are running privileged we
|
|
||||||
* first change the access mode and only then hand out
|
|
||||||
* ownership to avoid a window where access is too open. */
|
|
||||||
|
|
||||||
if (mode != MODE_INVALID)
|
|
||||||
if (chmod(path, mode) < 0)
|
|
||||||
return -errno;
|
|
||||||
|
|
||||||
if (uid != UID_INVALID || gid != GID_INVALID)
|
|
||||||
if (chown(path, uid, gid) < 0)
|
|
||||||
return -errno;
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int fchmod_and_fchown(int fd, mode_t mode, uid_t uid, gid_t gid) {
|
|
||||||
assert(fd >= 0);
|
|
||||||
|
|
||||||
/* Under the assumption that we are running privileged we
|
|
||||||
* first change the access mode and only then hand out
|
|
||||||
* ownership to avoid a window where access is too open. */
|
|
||||||
|
|
||||||
if (mode != MODE_INVALID)
|
|
||||||
if (fchmod(fd, mode) < 0)
|
|
||||||
return -errno;
|
|
||||||
|
|
||||||
if (uid != UID_INVALID || gid != GID_INVALID)
|
|
||||||
if (fchown(fd, uid, gid) < 0)
|
|
||||||
return -errno;
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int files_same(const char *filea, const char *fileb) {
|
int files_same(const char *filea, const char *fileb) {
|
||||||
struct stat a, b;
|
struct stat a, b;
|
||||||
|
|
||||||
|
@ -460,49 +254,6 @@ int running_in_chroot(void) {
|
||||||
return ret == 0;
|
return ret == 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int touch_file(const char *path, bool parents, usec_t stamp, uid_t uid, gid_t gid, mode_t mode) {
|
|
||||||
_cleanup_close_ int fd;
|
|
||||||
int r;
|
|
||||||
|
|
||||||
assert(path);
|
|
||||||
|
|
||||||
if (parents)
|
|
||||||
mkdir_parents(path, 0755);
|
|
||||||
|
|
||||||
fd = open(path, O_WRONLY|O_CREAT|O_CLOEXEC|O_NOCTTY, mode > 0 ? mode : 0644);
|
|
||||||
if (fd < 0)
|
|
||||||
return -errno;
|
|
||||||
|
|
||||||
if (mode > 0) {
|
|
||||||
r = fchmod(fd, mode);
|
|
||||||
if (r < 0)
|
|
||||||
return -errno;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (uid != UID_INVALID || gid != GID_INVALID) {
|
|
||||||
r = fchown(fd, uid, gid);
|
|
||||||
if (r < 0)
|
|
||||||
return -errno;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (stamp != USEC_INFINITY) {
|
|
||||||
struct timespec ts[2];
|
|
||||||
|
|
||||||
timespec_store(&ts[0], stamp);
|
|
||||||
ts[1] = ts[0];
|
|
||||||
r = futimens(fd, ts);
|
|
||||||
} else
|
|
||||||
r = futimens(fd, NULL);
|
|
||||||
if (r < 0)
|
|
||||||
return -errno;
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int touch(const char *path) {
|
|
||||||
return touch_file(path, false, USEC_INFINITY, UID_INVALID, GID_INVALID, 0);
|
|
||||||
}
|
|
||||||
|
|
||||||
noreturn void freeze(void) {
|
noreturn void freeze(void) {
|
||||||
|
|
||||||
/* Make sure nobody waits for us on a socket anymore */
|
/* Make sure nobody waits for us on a socket anymore */
|
||||||
|
@ -692,92 +443,6 @@ bool plymouth_running(void) {
|
||||||
return access("/run/plymouth/pid", F_OK) >= 0;
|
return access("/run/plymouth/pid", F_OK) >= 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int symlink_atomic(const char *from, const char *to) {
|
|
||||||
_cleanup_free_ char *t = NULL;
|
|
||||||
int r;
|
|
||||||
|
|
||||||
assert(from);
|
|
||||||
assert(to);
|
|
||||||
|
|
||||||
r = tempfn_random(to, NULL, &t);
|
|
||||||
if (r < 0)
|
|
||||||
return r;
|
|
||||||
|
|
||||||
if (symlink(from, t) < 0)
|
|
||||||
return -errno;
|
|
||||||
|
|
||||||
if (rename(t, to) < 0) {
|
|
||||||
unlink_noerrno(t);
|
|
||||||
return -errno;
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int symlink_idempotent(const char *from, const char *to) {
|
|
||||||
_cleanup_free_ char *p = NULL;
|
|
||||||
int r;
|
|
||||||
|
|
||||||
assert(from);
|
|
||||||
assert(to);
|
|
||||||
|
|
||||||
if (symlink(from, to) < 0) {
|
|
||||||
if (errno != EEXIST)
|
|
||||||
return -errno;
|
|
||||||
|
|
||||||
r = readlink_malloc(to, &p);
|
|
||||||
if (r < 0)
|
|
||||||
return r;
|
|
||||||
|
|
||||||
if (!streq(p, from))
|
|
||||||
return -EINVAL;
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int mknod_atomic(const char *path, mode_t mode, dev_t dev) {
|
|
||||||
_cleanup_free_ char *t = NULL;
|
|
||||||
int r;
|
|
||||||
|
|
||||||
assert(path);
|
|
||||||
|
|
||||||
r = tempfn_random(path, NULL, &t);
|
|
||||||
if (r < 0)
|
|
||||||
return r;
|
|
||||||
|
|
||||||
if (mknod(t, mode, dev) < 0)
|
|
||||||
return -errno;
|
|
||||||
|
|
||||||
if (rename(t, path) < 0) {
|
|
||||||
unlink_noerrno(t);
|
|
||||||
return -errno;
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int mkfifo_atomic(const char *path, mode_t mode) {
|
|
||||||
_cleanup_free_ char *t = NULL;
|
|
||||||
int r;
|
|
||||||
|
|
||||||
assert(path);
|
|
||||||
|
|
||||||
r = tempfn_random(path, NULL, &t);
|
|
||||||
if (r < 0)
|
|
||||||
return r;
|
|
||||||
|
|
||||||
if (mkfifo(t, mode) < 0)
|
|
||||||
return -errno;
|
|
||||||
|
|
||||||
if (rename(t, path) < 0) {
|
|
||||||
unlink_noerrno(t);
|
|
||||||
return -errno;
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool display_is_local(const char *display) {
|
bool display_is_local(const char *display) {
|
||||||
assert(display);
|
assert(display);
|
||||||
|
|
||||||
|
@ -855,58 +520,6 @@ int glob_extend(char ***strv, const char *path) {
|
||||||
return k;
|
return k;
|
||||||
}
|
}
|
||||||
|
|
||||||
int get_files_in_directory(const char *path, char ***list) {
|
|
||||||
_cleanup_closedir_ DIR *d = NULL;
|
|
||||||
size_t bufsize = 0, n = 0;
|
|
||||||
_cleanup_strv_free_ char **l = NULL;
|
|
||||||
|
|
||||||
assert(path);
|
|
||||||
|
|
||||||
/* Returns all files in a directory in *list, and the number
|
|
||||||
* of files as return value. If list is NULL returns only the
|
|
||||||
* number. */
|
|
||||||
|
|
||||||
d = opendir(path);
|
|
||||||
if (!d)
|
|
||||||
return -errno;
|
|
||||||
|
|
||||||
for (;;) {
|
|
||||||
struct dirent *de;
|
|
||||||
|
|
||||||
errno = 0;
|
|
||||||
de = readdir(d);
|
|
||||||
if (!de && errno != 0)
|
|
||||||
return -errno;
|
|
||||||
if (!de)
|
|
||||||
break;
|
|
||||||
|
|
||||||
dirent_ensure_type(d, de);
|
|
||||||
|
|
||||||
if (!dirent_is_file(de))
|
|
||||||
continue;
|
|
||||||
|
|
||||||
if (list) {
|
|
||||||
/* one extra slot is needed for the terminating NULL */
|
|
||||||
if (!GREEDY_REALLOC(l, bufsize, n + 2))
|
|
||||||
return -ENOMEM;
|
|
||||||
|
|
||||||
l[n] = strdup(de->d_name);
|
|
||||||
if (!l[n])
|
|
||||||
return -ENOMEM;
|
|
||||||
|
|
||||||
l[++n] = NULL;
|
|
||||||
} else
|
|
||||||
n++;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (list) {
|
|
||||||
*list = l;
|
|
||||||
l = NULL; /* avoid freeing */
|
|
||||||
}
|
|
||||||
|
|
||||||
return n;
|
|
||||||
}
|
|
||||||
|
|
||||||
bool is_main_thread(void) {
|
bool is_main_thread(void) {
|
||||||
static thread_local int cached = 0;
|
static thread_local int cached = 0;
|
||||||
|
|
||||||
|
@ -1815,24 +1428,6 @@ int namespace_enter(int pidns_fd, int mntns_fd, int netns_fd, int userns_fd, int
|
||||||
return reset_uid_gid();
|
return reset_uid_gid();
|
||||||
}
|
}
|
||||||
|
|
||||||
int fd_warn_permissions(const char *path, int fd) {
|
|
||||||
struct stat st;
|
|
||||||
|
|
||||||
if (fstat(fd, &st) < 0)
|
|
||||||
return -errno;
|
|
||||||
|
|
||||||
if (st.st_mode & 0111)
|
|
||||||
log_warning("Configuration file %s is marked executable. Please remove executable permission bits. Proceeding anyway.", path);
|
|
||||||
|
|
||||||
if (st.st_mode & 0002)
|
|
||||||
log_warning("Configuration file %s is marked world-writable. Please remove world writability permission bits. Proceeding anyway.", path);
|
|
||||||
|
|
||||||
if (getpid() == 1 && (st.st_mode & 0044) != 0044)
|
|
||||||
log_warning("Configuration file %s is marked world-inaccessible. This has no effect as configuration data is accessible via APIs without restrictions. Proceeding anyway.", path);
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
unsigned long personality_from_string(const char *p) {
|
unsigned long personality_from_string(const char *p) {
|
||||||
|
|
||||||
/* Parse a personality specifier. We introduce our own
|
/* Parse a personality specifier. We introduce our own
|
||||||
|
@ -2017,46 +1612,6 @@ ssize_t string_table_lookup(const char * const *table, size_t len, const char *k
|
||||||
return -1;
|
return -1;
|
||||||
}
|
}
|
||||||
|
|
||||||
int rename_noreplace(int olddirfd, const char *oldpath, int newdirfd, const char *newpath) {
|
|
||||||
struct stat buf;
|
|
||||||
int ret;
|
|
||||||
|
|
||||||
ret = renameat2(olddirfd, oldpath, newdirfd, newpath, RENAME_NOREPLACE);
|
|
||||||
if (ret >= 0)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
/* renameat2() exists since Linux 3.15, btrfs added support for it later.
|
|
||||||
* If it is not implemented, fallback to another method. */
|
|
||||||
if (!IN_SET(errno, EINVAL, ENOSYS))
|
|
||||||
return -errno;
|
|
||||||
|
|
||||||
/* The link()/unlink() fallback does not work on directories. But
|
|
||||||
* renameat() without RENAME_NOREPLACE gives the same semantics on
|
|
||||||
* directories, except when newpath is an *empty* directory. This is
|
|
||||||
* good enough. */
|
|
||||||
ret = fstatat(olddirfd, oldpath, &buf, AT_SYMLINK_NOFOLLOW);
|
|
||||||
if (ret >= 0 && S_ISDIR(buf.st_mode)) {
|
|
||||||
ret = renameat(olddirfd, oldpath, newdirfd, newpath);
|
|
||||||
return ret >= 0 ? 0 : -errno;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* If it is not a directory, use the link()/unlink() fallback. */
|
|
||||||
ret = linkat(olddirfd, oldpath, newdirfd, newpath, 0);
|
|
||||||
if (ret < 0)
|
|
||||||
return -errno;
|
|
||||||
|
|
||||||
ret = unlinkat(olddirfd, oldpath, 0);
|
|
||||||
if (ret < 0) {
|
|
||||||
/* backup errno before the following unlinkat() alters it */
|
|
||||||
ret = errno;
|
|
||||||
(void) unlinkat(newdirfd, newpath, 0);
|
|
||||||
errno = ret;
|
|
||||||
return -errno;
|
|
||||||
}
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int version(void) {
|
int version(void) {
|
||||||
puts(PACKAGE_STRING "\n"
|
puts(PACKAGE_STRING "\n"
|
||||||
SYSTEMD_FEATURES);
|
SYSTEMD_FEATURES);
|
||||||
|
|
|
@ -83,14 +83,6 @@ static inline const char* one_zero(bool b) {
|
||||||
return b ? "1" : "0";
|
return b ? "1" : "0";
|
||||||
}
|
}
|
||||||
|
|
||||||
int readlinkat_malloc(int fd, const char *p, char **ret);
|
|
||||||
int readlink_malloc(const char *p, char **r);
|
|
||||||
int readlink_value(const char *p, char **ret);
|
|
||||||
int readlink_and_make_absolute(const char *p, char **r);
|
|
||||||
int readlink_and_canonicalize(const char *p, char **r);
|
|
||||||
|
|
||||||
int rmdir_parents(const char *path, const char *stop);
|
|
||||||
|
|
||||||
/* For basic lookup tables with strictly enumerated entries */
|
/* For basic lookup tables with strictly enumerated entries */
|
||||||
#define _DEFINE_STRING_TABLE_LOOKUP_TO_STRING(name,type,scope) \
|
#define _DEFINE_STRING_TABLE_LOOKUP_TO_STRING(name,type,scope) \
|
||||||
scope const char *name##_to_string(type i) { \
|
scope const char *name##_to_string(type i) { \
|
||||||
|
@ -159,9 +151,6 @@ static inline int dir_is_populated(const char *path) {
|
||||||
return !r;
|
return !r;
|
||||||
}
|
}
|
||||||
|
|
||||||
int chmod_and_chown(const char *path, mode_t mode, uid_t uid, gid_t gid);
|
|
||||||
int fchmod_and_fchown(int fd, mode_t mode, uid_t uid, gid_t gid);
|
|
||||||
|
|
||||||
typedef long statfs_f_type_t;
|
typedef long statfs_f_type_t;
|
||||||
|
|
||||||
bool is_fs_type(const struct statfs *s, statfs_f_type_t magic_value) _pure_;
|
bool is_fs_type(const struct statfs *s, statfs_f_type_t magic_value) _pure_;
|
||||||
|
@ -179,9 +168,6 @@ int files_same(const char *filea, const char *fileb);
|
||||||
|
|
||||||
int running_in_chroot(void);
|
int running_in_chroot(void);
|
||||||
|
|
||||||
int touch_file(const char *path, bool parents, usec_t stamp, uid_t uid, gid_t gid, mode_t mode);
|
|
||||||
int touch(const char *path);
|
|
||||||
|
|
||||||
noreturn void freeze(void);
|
noreturn void freeze(void);
|
||||||
|
|
||||||
bool null_or_empty(struct stat *st) _pure_;
|
bool null_or_empty(struct stat *st) _pure_;
|
||||||
|
@ -192,22 +178,12 @@ void execute_directories(const char* const* directories, usec_t timeout, char *a
|
||||||
|
|
||||||
bool plymouth_running(void);
|
bool plymouth_running(void);
|
||||||
|
|
||||||
int symlink_idempotent(const char *from, const char *to);
|
|
||||||
|
|
||||||
int symlink_atomic(const char *from, const char *to);
|
|
||||||
int mknod_atomic(const char *path, mode_t mode, dev_t dev);
|
|
||||||
int mkfifo_atomic(const char *path, mode_t mode);
|
|
||||||
|
|
||||||
int fchmod_umask(int fd, mode_t mode);
|
|
||||||
|
|
||||||
bool display_is_local(const char *display) _pure_;
|
bool display_is_local(const char *display) _pure_;
|
||||||
int socket_from_display(const char *display, char **path);
|
int socket_from_display(const char *display, char **path);
|
||||||
|
|
||||||
int glob_exists(const char *path);
|
int glob_exists(const char *path);
|
||||||
int glob_extend(char ***strv, const char *path);
|
int glob_extend(char ***strv, const char *path);
|
||||||
|
|
||||||
int get_files_in_directory(const char *path, char ***list);
|
|
||||||
|
|
||||||
bool is_main_thread(void);
|
bool is_main_thread(void);
|
||||||
|
|
||||||
int block_get_whole_disk(dev_t d, dev_t *ret);
|
int block_get_whole_disk(dev_t d, dev_t *ret);
|
||||||
|
@ -408,8 +384,6 @@ static inline unsigned log2u_round_up(unsigned x) {
|
||||||
ans; \
|
ans; \
|
||||||
})
|
})
|
||||||
|
|
||||||
int unlink_noerrno(const char *path);
|
|
||||||
|
|
||||||
#define alloca0(n) \
|
#define alloca0(n) \
|
||||||
({ \
|
({ \
|
||||||
char *_new_; \
|
char *_new_; \
|
||||||
|
@ -460,8 +434,6 @@ int container_get_leader(const char *machine, pid_t *pid);
|
||||||
int namespace_open(pid_t pid, int *pidns_fd, int *mntns_fd, int *netns_fd, int *userns_fd, int *root_fd);
|
int namespace_open(pid_t pid, int *pidns_fd, int *mntns_fd, int *netns_fd, int *userns_fd, int *root_fd);
|
||||||
int namespace_enter(int pidns_fd, int mntns_fd, int netns_fd, int userns_fd, int root_fd);
|
int namespace_enter(int pidns_fd, int mntns_fd, int netns_fd, int userns_fd, int root_fd);
|
||||||
|
|
||||||
int fd_warn_permissions(const char *path, int fd);
|
|
||||||
|
|
||||||
#ifndef PERSONALITY_INVALID
|
#ifndef PERSONALITY_INVALID
|
||||||
/* personality(7) documents that 0xffffffffUL is used for querying the
|
/* personality(7) documents that 0xffffffffUL is used for querying the
|
||||||
* current personality, hence let's use that here as error
|
* current personality, hence let's use that here as error
|
||||||
|
@ -498,12 +470,8 @@ union inotify_event_buffer {
|
||||||
uint8_t raw[INOTIFY_EVENT_MAX];
|
uint8_t raw[INOTIFY_EVENT_MAX];
|
||||||
};
|
};
|
||||||
|
|
||||||
#define laccess(path, mode) faccessat(AT_FDCWD, (path), (mode), AT_SYMLINK_NOFOLLOW)
|
|
||||||
|
|
||||||
int syslog_parse_priority(const char **p, int *priority, bool with_facility);
|
int syslog_parse_priority(const char **p, int *priority, bool with_facility);
|
||||||
|
|
||||||
int rename_noreplace(int olddirfd, const char *oldpath, int newdirfd, const char *newpath);
|
|
||||||
|
|
||||||
int version(void);
|
int version(void);
|
||||||
|
|
||||||
bool fdname_is_valid(const char *s);
|
bool fdname_is_valid(const char *s);
|
||||||
|
|
|
@ -69,6 +69,7 @@
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
#include "fileio.h"
|
#include "fileio.h"
|
||||||
#include "formats-util.h"
|
#include "formats-util.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "io-util.h"
|
#include "io-util.h"
|
||||||
#include "ioprio.h"
|
#include "ioprio.h"
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
|
|
|
@ -44,6 +44,7 @@
|
||||||
#include "errno-list.h"
|
#include "errno-list.h"
|
||||||
#include "escape.h"
|
#include "escape.h"
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "ioprio.h"
|
#include "ioprio.h"
|
||||||
#include "load-fragment.h"
|
#include "load-fragment.h"
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
|
|
|
@ -31,6 +31,7 @@
|
||||||
|
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
#include "fileio.h"
|
#include "fileio.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "hexdecoct.h"
|
#include "hexdecoct.h"
|
||||||
#include "io-util.h"
|
#include "io-util.h"
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
|
|
|
@ -55,6 +55,7 @@
|
||||||
#include "fdset.h"
|
#include "fdset.h"
|
||||||
#include "fileio.h"
|
#include "fileio.h"
|
||||||
#include "formats-util.h"
|
#include "formats-util.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "hostname-setup.h"
|
#include "hostname-setup.h"
|
||||||
#include "ima-setup.h"
|
#include "ima-setup.h"
|
||||||
#include "killall.h"
|
#include "killall.h"
|
||||||
|
|
|
@ -55,6 +55,7 @@
|
||||||
#include "exit-status.h"
|
#include "exit-status.h"
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
#include "fileio.h"
|
#include "fileio.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "hashmap.h"
|
#include "hashmap.h"
|
||||||
#include "io-util.h"
|
#include "io-util.h"
|
||||||
#include "locale-setup.h"
|
#include "locale-setup.h"
|
||||||
|
|
|
@ -35,6 +35,7 @@
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
#include "fileio.h"
|
#include "fileio.h"
|
||||||
#include "formats-util.h"
|
#include "formats-util.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "load-dropin.h"
|
#include "load-dropin.h"
|
||||||
#include "load-fragment.h"
|
#include "load-fragment.h"
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
|
|
|
@ -24,6 +24,7 @@
|
||||||
#include "bus-error.h"
|
#include "bus-error.h"
|
||||||
#include "bus-util.h"
|
#include "bus-util.h"
|
||||||
#include "dbus-timer.h"
|
#include "dbus-timer.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "parse-util.h"
|
#include "parse-util.h"
|
||||||
#include "special.h"
|
#include "special.h"
|
||||||
#include "string-util.h"
|
#include "string-util.h"
|
||||||
|
|
|
@ -28,6 +28,7 @@
|
||||||
|
|
||||||
#include "dirent-util.h"
|
#include "dirent-util.h"
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "hashmap.h"
|
#include "hashmap.h"
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
#include "pager.h"
|
#include "pager.h"
|
||||||
|
|
|
@ -28,6 +28,7 @@
|
||||||
#include "copy.h"
|
#include "copy.h"
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
#include "fileio.h"
|
#include "fileio.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "hostname-util.h"
|
#include "hostname-util.h"
|
||||||
#include "locale-util.h"
|
#include "locale-util.h"
|
||||||
#include "mkdir.h"
|
#include "mkdir.h"
|
||||||
|
|
|
@ -37,6 +37,7 @@
|
||||||
#include "bus-util.h"
|
#include "bus-util.h"
|
||||||
#include "device-util.h"
|
#include "device-util.h"
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "parse-util.h"
|
#include "parse-util.h"
|
||||||
#include "path-util.h"
|
#include "path-util.h"
|
||||||
#include "process-util.h"
|
#include "process-util.h"
|
||||||
|
|
|
@ -25,6 +25,7 @@
|
||||||
#include "conf-files.h"
|
#include "conf-files.h"
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
#include "fileio.h"
|
#include "fileio.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "hwdb-internal.h"
|
#include "hwdb-internal.h"
|
||||||
#include "hwdb-util.h"
|
#include "hwdb-util.h"
|
||||||
#include "mkdir.h"
|
#include "mkdir.h"
|
||||||
|
|
|
@ -27,6 +27,7 @@
|
||||||
#include "export-raw.h"
|
#include "export-raw.h"
|
||||||
#include "export-tar.h"
|
#include "export-tar.h"
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "hostname-util.h"
|
#include "hostname-util.h"
|
||||||
#include "import-util.h"
|
#include "import-util.h"
|
||||||
#include "machine-image.h"
|
#include "machine-image.h"
|
||||||
|
|
|
@ -29,6 +29,7 @@
|
||||||
#include "copy.h"
|
#include "copy.h"
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
#include "fileio.h"
|
#include "fileio.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "hostname-util.h"
|
#include "hostname-util.h"
|
||||||
#include "import-common.h"
|
#include "import-common.h"
|
||||||
#include "import-compress.h"
|
#include "import-compress.h"
|
||||||
|
|
|
@ -28,6 +28,7 @@
|
||||||
#include "copy.h"
|
#include "copy.h"
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
#include "fileio.h"
|
#include "fileio.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "hostname-util.h"
|
#include "hostname-util.h"
|
||||||
#include "import-common.h"
|
#include "import-common.h"
|
||||||
#include "import-compress.h"
|
#include "import-compress.h"
|
||||||
|
|
|
@ -25,6 +25,7 @@
|
||||||
|
|
||||||
#include "event-util.h"
|
#include "event-util.h"
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "hostname-util.h"
|
#include "hostname-util.h"
|
||||||
#include "import-raw.h"
|
#include "import-raw.h"
|
||||||
#include "import-tar.h"
|
#include "import-tar.h"
|
||||||
|
|
|
@ -29,6 +29,7 @@
|
||||||
#include "curl-util.h"
|
#include "curl-util.h"
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
#include "fileio.h"
|
#include "fileio.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "hostname-util.h"
|
#include "hostname-util.h"
|
||||||
#include "import-common.h"
|
#include "import-common.h"
|
||||||
#include "import-util.h"
|
#include "import-util.h"
|
||||||
|
|
|
@ -31,6 +31,7 @@
|
||||||
#include "curl-util.h"
|
#include "curl-util.h"
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
#include "fileio.h"
|
#include "fileio.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "hostname-util.h"
|
#include "hostname-util.h"
|
||||||
#include "import-common.h"
|
#include "import-common.h"
|
||||||
#include "import-util.h"
|
#include "import-util.h"
|
||||||
|
|
|
@ -29,6 +29,7 @@
|
||||||
#include "curl-util.h"
|
#include "curl-util.h"
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
#include "fileio.h"
|
#include "fileio.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "hostname-util.h"
|
#include "hostname-util.h"
|
||||||
#include "import-common.h"
|
#include "import-common.h"
|
||||||
#include "import-util.h"
|
#include "import-util.h"
|
||||||
|
|
|
@ -44,6 +44,7 @@
|
||||||
#include "escape.h"
|
#include "escape.h"
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
#include "fileio.h"
|
#include "fileio.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "journald-native.h"
|
#include "journald-native.h"
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
#include "macro.h"
|
#include "macro.h"
|
||||||
|
|
|
@ -45,6 +45,7 @@
|
||||||
#include "chattr-util.h"
|
#include "chattr-util.h"
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
#include "fileio.h"
|
#include "fileio.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "fsprg.h"
|
#include "fsprg.h"
|
||||||
#include "hostname-util.h"
|
#include "hostname-util.h"
|
||||||
#include "io-util.h"
|
#include "io-util.h"
|
||||||
|
|
|
@ -25,6 +25,7 @@
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "journald-console.h"
|
#include "journald-console.h"
|
||||||
#include "journald-kmsg.h"
|
#include "journald-kmsg.h"
|
||||||
#include "journald-native.h"
|
#include "journald-native.h"
|
||||||
|
|
|
@ -40,6 +40,7 @@
|
||||||
#include "extract-word.h"
|
#include "extract-word.h"
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
#include "formats-util.h"
|
#include "formats-util.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "hashmap.h"
|
#include "hashmap.h"
|
||||||
#include "hostname-util.h"
|
#include "hostname-util.h"
|
||||||
#include "journal-authenticate.h"
|
#include "journal-authenticate.h"
|
||||||
|
|
|
@ -36,6 +36,7 @@
|
||||||
#include "sd-daemon.h"
|
#include "sd-daemon.h"
|
||||||
|
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "parse-util.h"
|
#include "parse-util.h"
|
||||||
#include "path-util.h"
|
#include "path-util.h"
|
||||||
#include "socket-util.h"
|
#include "socket-util.h"
|
||||||
|
|
|
@ -29,6 +29,7 @@
|
||||||
#include "device-util.h"
|
#include "device-util.h"
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
#include "fileio.h"
|
#include "fileio.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "hashmap.h"
|
#include "hashmap.h"
|
||||||
#include "macro.h"
|
#include "macro.h"
|
||||||
#include "mkdir.h"
|
#include "mkdir.h"
|
||||||
|
|
|
@ -29,6 +29,7 @@
|
||||||
#include "device-util.h"
|
#include "device-util.h"
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
#include "fileio.h"
|
#include "fileio.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "hashmap.h"
|
#include "hashmap.h"
|
||||||
#include "macro.h"
|
#include "macro.h"
|
||||||
#include "parse-util.h"
|
#include "parse-util.h"
|
||||||
|
|
|
@ -28,10 +28,12 @@
|
||||||
#include "sd-login.h"
|
#include "sd-login.h"
|
||||||
|
|
||||||
#include "cgroup-util.h"
|
#include "cgroup-util.h"
|
||||||
|
#include "dirent-util.h"
|
||||||
#include "escape.h"
|
#include "escape.h"
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
#include "fileio.h"
|
#include "fileio.h"
|
||||||
#include "formats-util.h"
|
#include "formats-util.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "hostname-util.h"
|
#include "hostname-util.h"
|
||||||
#include "io-util.h"
|
#include "io-util.h"
|
||||||
#include "login-util.h"
|
#include "login-util.h"
|
||||||
|
@ -43,7 +45,6 @@
|
||||||
#include "strv.h"
|
#include "strv.h"
|
||||||
#include "user-util.h"
|
#include "user-util.h"
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
#include "dirent-util.h"
|
|
||||||
|
|
||||||
/* Error codes:
|
/* Error codes:
|
||||||
*
|
*
|
||||||
|
|
|
@ -36,6 +36,7 @@
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
#include "fileio-label.h"
|
#include "fileio-label.h"
|
||||||
#include "formats-util.h"
|
#include "formats-util.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "logind.h"
|
#include "logind.h"
|
||||||
#include "mkdir.h"
|
#include "mkdir.h"
|
||||||
#include "path-util.h"
|
#include "path-util.h"
|
||||||
|
|
|
@ -32,6 +32,7 @@
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
#include "fileio.h"
|
#include "fileio.h"
|
||||||
#include "formats-util.h"
|
#include "formats-util.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "hashmap.h"
|
#include "hashmap.h"
|
||||||
#include "label.h"
|
#include "label.h"
|
||||||
#include "logind-user.h"
|
#include "logind-user.h"
|
||||||
|
|
|
@ -38,6 +38,7 @@
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
#include "fileio.h"
|
#include "fileio.h"
|
||||||
#include "formats-util.h"
|
#include "formats-util.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "in-addr-util.h"
|
#include "in-addr-util.h"
|
||||||
#include "local-addresses.h"
|
#include "local-addresses.h"
|
||||||
#include "machine-dbus.h"
|
#include "machine-dbus.h"
|
||||||
|
|
|
@ -24,6 +24,7 @@
|
||||||
|
|
||||||
#include "cgroup-util.h"
|
#include "cgroup-util.h"
|
||||||
#include "escape.h"
|
#include "escape.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "label.h"
|
#include "label.h"
|
||||||
#include "mkdir.h"
|
#include "mkdir.h"
|
||||||
#include "mount-util.h"
|
#include "mount-util.h"
|
||||||
|
|
|
@ -61,6 +61,7 @@
|
||||||
#include "fdset.h"
|
#include "fdset.h"
|
||||||
#include "fileio.h"
|
#include "fileio.h"
|
||||||
#include "formats-util.h"
|
#include "formats-util.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "gpt.h"
|
#include "gpt.h"
|
||||||
#include "hostname-util.h"
|
#include "hostname-util.h"
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
|
|
|
@ -29,6 +29,7 @@
|
||||||
#include "conf-files.h"
|
#include "conf-files.h"
|
||||||
#include "conf-parser.h"
|
#include "conf-parser.h"
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
#include "macro.h"
|
#include "macro.h"
|
||||||
#include "parse-util.h"
|
#include "parse-util.h"
|
||||||
|
|
|
@ -29,6 +29,7 @@
|
||||||
#include "conf-parser.h"
|
#include "conf-parser.h"
|
||||||
#include "dirent-util.h"
|
#include "dirent-util.h"
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "hashmap.h"
|
#include "hashmap.h"
|
||||||
#include "install-printf.h"
|
#include "install-printf.h"
|
||||||
#include "install.h"
|
#include "install.h"
|
||||||
|
|
|
@ -28,6 +28,7 @@
|
||||||
#include "copy.h"
|
#include "copy.h"
|
||||||
#include "dirent-util.h"
|
#include "dirent-util.h"
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "machine-image.h"
|
#include "machine-image.h"
|
||||||
#include "mkdir.h"
|
#include "mkdir.h"
|
||||||
#include "path-util.h"
|
#include "path-util.h"
|
||||||
|
|
|
@ -27,16 +27,17 @@
|
||||||
#include "btrfs-util.h"
|
#include "btrfs-util.h"
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
#include "fileio.h"
|
#include "fileio.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "lockfile-util.h"
|
#include "lockfile-util.h"
|
||||||
#include "machine-pool.h"
|
#include "machine-pool.h"
|
||||||
#include "mkdir.h"
|
#include "mkdir.h"
|
||||||
|
#include "mount-util.h"
|
||||||
#include "parse-util.h"
|
#include "parse-util.h"
|
||||||
#include "path-util.h"
|
#include "path-util.h"
|
||||||
#include "process-util.h"
|
#include "process-util.h"
|
||||||
#include "signal-util.h"
|
#include "signal-util.h"
|
||||||
#include "string-util.h"
|
#include "string-util.h"
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
#include "mount-util.h"
|
|
||||||
|
|
||||||
#define VAR_LIB_MACHINES_SIZE_START (1024UL*1024UL*500UL)
|
#define VAR_LIB_MACHINES_SIZE_START (1024UL*1024UL*500UL)
|
||||||
#define VAR_LIB_MACHINES_FREE_MIN (1024UL*1024UL*750UL)
|
#define VAR_LIB_MACHINES_FREE_MIN (1024UL*1024UL*750UL)
|
||||||
|
|
|
@ -22,6 +22,7 @@
|
||||||
#include <errno.h>
|
#include <errno.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
|
||||||
|
#include "fs-util.h"
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
#include "string-util.h"
|
#include "string-util.h"
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
|
|
|
@ -51,6 +51,7 @@
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
#include "fileio.h"
|
#include "fileio.h"
|
||||||
#include "formats-util.h"
|
#include "formats-util.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "hostname-util.h"
|
#include "hostname-util.h"
|
||||||
#include "initreq.h"
|
#include "initreq.h"
|
||||||
#include "install.h"
|
#include "install.h"
|
||||||
|
|
|
@ -23,6 +23,7 @@
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
||||||
#include "conf-files.h"
|
#include "conf-files.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "macro.h"
|
#include "macro.h"
|
||||||
#include "rm-rf.h"
|
#include "rm-rf.h"
|
||||||
#include "string-util.h"
|
#include "string-util.h"
|
||||||
|
|
|
@ -22,6 +22,7 @@
|
||||||
#include "copy.h"
|
#include "copy.h"
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
#include "fileio.h"
|
#include "fileio.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "macro.h"
|
#include "macro.h"
|
||||||
#include "mkdir.h"
|
#include "mkdir.h"
|
||||||
#include "path-util.h"
|
#include "path-util.h"
|
||||||
|
|
|
@ -19,12 +19,13 @@
|
||||||
|
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
||||||
#include "unit.h"
|
#include "fs-util.h"
|
||||||
#include "manager.h"
|
|
||||||
#include "util.h"
|
|
||||||
#include "macro.h"
|
#include "macro.h"
|
||||||
|
#include "manager.h"
|
||||||
#include "mkdir.h"
|
#include "mkdir.h"
|
||||||
#include "rm-rf.h"
|
#include "rm-rf.h"
|
||||||
|
#include "unit.h"
|
||||||
|
#include "util.h"
|
||||||
|
|
||||||
typedef void (*test_function_t)(Manager *m);
|
typedef void (*test_function_t)(Manager *m);
|
||||||
|
|
||||||
|
|
|
@ -20,6 +20,8 @@
|
||||||
#include <stdbool.h>
|
#include <stdbool.h>
|
||||||
#include <stdio.h>
|
#include <stdio.h>
|
||||||
|
|
||||||
|
#include "fd-util.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "macro.h"
|
#include "macro.h"
|
||||||
#include "manager.h"
|
#include "manager.h"
|
||||||
#include "mkdir.h"
|
#include "mkdir.h"
|
||||||
|
@ -28,7 +30,6 @@
|
||||||
#include "strv.h"
|
#include "strv.h"
|
||||||
#include "unit.h"
|
#include "unit.h"
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
#include "fd-util.h"
|
|
||||||
|
|
||||||
typedef void (*test_function_t)(Manager *m);
|
typedef void (*test_function_t)(Manager *m);
|
||||||
|
|
||||||
|
|
|
@ -26,6 +26,7 @@
|
||||||
#include <sys/signalfd.h>
|
#include <sys/signalfd.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
|
||||||
|
#include "fs-util.h"
|
||||||
#include "missing.h"
|
#include "missing.h"
|
||||||
#include "selinux-util.h"
|
#include "selinux-util.h"
|
||||||
#include "signal-util.h"
|
#include "signal-util.h"
|
||||||
|
|
|
@ -37,6 +37,7 @@
|
||||||
#include "escape.h"
|
#include "escape.h"
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
#include "fileio.h"
|
#include "fileio.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "fstab-util.h"
|
#include "fstab-util.h"
|
||||||
#include "hexdecoct.h"
|
#include "hexdecoct.h"
|
||||||
#include "io-util.h"
|
#include "io-util.h"
|
||||||
|
|
|
@ -23,21 +23,22 @@
|
||||||
#include <string.h>
|
#include <string.h>
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
|
||||||
#include "sd-messages.h"
|
|
||||||
#include "sd-event.h"
|
|
||||||
#include "sd-bus.h"
|
#include "sd-bus.h"
|
||||||
|
#include "sd-event.h"
|
||||||
|
#include "sd-messages.h"
|
||||||
|
|
||||||
#include "util.h"
|
|
||||||
#include "strv.h"
|
|
||||||
#include "def.h"
|
|
||||||
#include "clock-util.h"
|
|
||||||
#include "path-util.h"
|
|
||||||
#include "fileio-label.h"
|
|
||||||
#include "bus-util.h"
|
|
||||||
#include "bus-error.h"
|
|
||||||
#include "bus-common-errors.h"
|
#include "bus-common-errors.h"
|
||||||
|
#include "bus-error.h"
|
||||||
|
#include "bus-util.h"
|
||||||
|
#include "clock-util.h"
|
||||||
|
#include "def.h"
|
||||||
#include "event-util.h"
|
#include "event-util.h"
|
||||||
|
#include "fileio-label.h"
|
||||||
|
#include "fs-util.h"
|
||||||
|
#include "path-util.h"
|
||||||
#include "selinux-util.h"
|
#include "selinux-util.h"
|
||||||
|
#include "strv.h"
|
||||||
|
#include "util.h"
|
||||||
|
|
||||||
#define NULL_ADJTIME_UTC "0.0 0 0\n0\nUTC\n"
|
#define NULL_ADJTIME_UTC "0.0 0 0\n0\nUTC\n"
|
||||||
#define NULL_ADJTIME_LOCAL "0.0 0 0\n0\nLOCAL\n"
|
#define NULL_ADJTIME_LOCAL "0.0 0 0\n0\nLOCAL\n"
|
||||||
|
|
|
@ -34,6 +34,7 @@
|
||||||
#include "sd-daemon.h"
|
#include "sd-daemon.h"
|
||||||
|
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "list.h"
|
#include "list.h"
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
#include "missing.h"
|
#include "missing.h"
|
||||||
|
|
|
@ -25,6 +25,7 @@
|
||||||
#include "capability.h"
|
#include "capability.h"
|
||||||
#include "clock-util.h"
|
#include "clock-util.h"
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "network-util.h"
|
#include "network-util.h"
|
||||||
#include "signal-util.h"
|
#include "signal-util.h"
|
||||||
#include "timesyncd-conf.h"
|
#include "timesyncd-conf.h"
|
||||||
|
|
|
@ -48,6 +48,7 @@
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
#include "fileio.h"
|
#include "fileio.h"
|
||||||
#include "formats-util.h"
|
#include "formats-util.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "io-util.h"
|
#include "io-util.h"
|
||||||
#include "label.h"
|
#include "label.h"
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
|
|
|
@ -26,6 +26,7 @@
|
||||||
#include <unistd.h>
|
#include <unistd.h>
|
||||||
|
|
||||||
#include "formats-util.h"
|
#include "formats-util.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "selinux-util.h"
|
#include "selinux-util.h"
|
||||||
#include "smack-util.h"
|
#include "smack-util.h"
|
||||||
#include "string-util.h"
|
#include "string-util.h"
|
||||||
|
|
|
@ -24,6 +24,7 @@
|
||||||
|
|
||||||
#include "conf-files.h"
|
#include "conf-files.h"
|
||||||
#include "fileio.h"
|
#include "fileio.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "hwdb-internal.h"
|
#include "hwdb-internal.h"
|
||||||
#include "hwdb-util.h"
|
#include "hwdb-util.h"
|
||||||
#include "strbuf.h"
|
#include "strbuf.h"
|
||||||
|
|
|
@ -50,6 +50,7 @@
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
#include "fileio.h"
|
#include "fileio.h"
|
||||||
#include "formats-util.h"
|
#include "formats-util.h"
|
||||||
|
#include "fs-util.h"
|
||||||
#include "hashmap.h"
|
#include "hashmap.h"
|
||||||
#include "io-util.h"
|
#include "io-util.h"
|
||||||
#include "netlink-util.h"
|
#include "netlink-util.h"
|
||||||
|
|
Loading…
Reference in New Issue