util-lib: split stat()/statfs()/stavfs() related calls into stat-util.[ch]
This commit is contained in:
parent
f3e2e81d53
commit
8fcde01280
|
@ -801,6 +801,8 @@ libbasic_la_SOURCES = \
|
||||||
src/basic/chattr-util.h \
|
src/basic/chattr-util.h \
|
||||||
src/basic/fs-util.c \
|
src/basic/fs-util.c \
|
||||||
src/basic/fs-util.h \
|
src/basic/fs-util.h \
|
||||||
|
src/basic/stat-util.c \
|
||||||
|
src/basic/stat-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 \
|
||||||
|
|
|
@ -25,6 +25,7 @@
|
||||||
#include "fs-util.h"
|
#include "fs-util.h"
|
||||||
#include "mkdir.h"
|
#include "mkdir.h"
|
||||||
#include "path-util.h"
|
#include "path-util.h"
|
||||||
|
#include "stat-util.h"
|
||||||
#include "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) {
|
||||||
|
|
|
@ -41,6 +41,7 @@
|
||||||
#include "missing.h"
|
#include "missing.h"
|
||||||
#include "parse-util.h"
|
#include "parse-util.h"
|
||||||
#include "path-util.h"
|
#include "path-util.h"
|
||||||
|
#include "stat-util.h"
|
||||||
#include "string-util.h"
|
#include "string-util.h"
|
||||||
#include "strv.h"
|
#include "strv.h"
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
|
@ -455,43 +456,6 @@ char* path_join(const char *root, const char *path, const char *rest) {
|
||||||
NULL);
|
NULL);
|
||||||
}
|
}
|
||||||
|
|
||||||
int path_is_read_only_fs(const char *path) {
|
|
||||||
struct statvfs st;
|
|
||||||
|
|
||||||
assert(path);
|
|
||||||
|
|
||||||
if (statvfs(path, &st) < 0)
|
|
||||||
return -errno;
|
|
||||||
|
|
||||||
if (st.f_flag & ST_RDONLY)
|
|
||||||
return true;
|
|
||||||
|
|
||||||
/* On NFS, statvfs() might not reflect whether we can actually
|
|
||||||
* write to the remote share. Let's try again with
|
|
||||||
* access(W_OK) which is more reliable, at least sometimes. */
|
|
||||||
if (access(path, W_OK) < 0 && errno == EROFS)
|
|
||||||
return true;
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
int path_is_os_tree(const char *path) {
|
|
||||||
char *p;
|
|
||||||
int r;
|
|
||||||
|
|
||||||
/* We use /usr/lib/os-release as flag file if something is an OS */
|
|
||||||
p = strjoina(path, "/usr/lib/os-release");
|
|
||||||
r = access(p, F_OK);
|
|
||||||
if (r >= 0)
|
|
||||||
return 1;
|
|
||||||
|
|
||||||
/* Also check for the old location in /etc, just in case. */
|
|
||||||
p = strjoina(path, "/etc/os-release");
|
|
||||||
r = access(p, F_OK);
|
|
||||||
|
|
||||||
return r >= 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
int find_binary(const char *name, char **ret) {
|
int find_binary(const char *name, char **ret) {
|
||||||
int last_error, r;
|
int last_error, r;
|
||||||
const char *p;
|
const char *p;
|
||||||
|
|
|
@ -52,9 +52,6 @@ int path_strv_make_absolute_cwd(char **l);
|
||||||
char** path_strv_resolve(char **l, const char *prefix);
|
char** path_strv_resolve(char **l, const char *prefix);
|
||||||
char** path_strv_resolve_uniq(char **l, const char *prefix);
|
char** path_strv_resolve_uniq(char **l, const char *prefix);
|
||||||
|
|
||||||
int path_is_read_only_fs(const char *path);
|
|
||||||
int path_is_os_tree(const char *path);
|
|
||||||
|
|
||||||
int find_binary(const char *name, char **filename);
|
int find_binary(const char *name, char **filename);
|
||||||
|
|
||||||
bool paths_check_timestamp(const char* const* paths, usec_t *paths_ts_usec, bool update);
|
bool paths_check_timestamp(const char* const* paths, usec_t *paths_ts_usec, bool update);
|
||||||
|
|
|
@ -24,6 +24,7 @@
|
||||||
#include "mount-util.h"
|
#include "mount-util.h"
|
||||||
#include "path-util.h"
|
#include "path-util.h"
|
||||||
#include "rm-rf.h"
|
#include "rm-rf.h"
|
||||||
|
#include "stat-util.h"
|
||||||
#include "string-util.h"
|
#include "string-util.h"
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
|
|
||||||
|
|
216
src/basic/stat-util.c
Normal file
216
src/basic/stat-util.c
Normal file
|
@ -0,0 +1,216 @@
|
||||||
|
/*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/
|
||||||
|
|
||||||
|
/***
|
||||||
|
This file is part of systemd.
|
||||||
|
|
||||||
|
Copyright 2010-2012 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 <fcntl.h>
|
||||||
|
#include <linux/magic.h>
|
||||||
|
#include <sys/statvfs.h>
|
||||||
|
#include <unistd.h>
|
||||||
|
|
||||||
|
#include "dirent-util.h"
|
||||||
|
#include "fd-util.h"
|
||||||
|
#include "macro.h"
|
||||||
|
#include "missing.h"
|
||||||
|
#include "stat-util.h"
|
||||||
|
#include "string-util.h"
|
||||||
|
|
||||||
|
int is_symlink(const char *path) {
|
||||||
|
struct stat info;
|
||||||
|
|
||||||
|
assert(path);
|
||||||
|
|
||||||
|
if (lstat(path, &info) < 0)
|
||||||
|
return -errno;
|
||||||
|
|
||||||
|
return !!S_ISLNK(info.st_mode);
|
||||||
|
}
|
||||||
|
|
||||||
|
int is_dir(const char* path, bool follow) {
|
||||||
|
struct stat st;
|
||||||
|
int r;
|
||||||
|
|
||||||
|
assert(path);
|
||||||
|
|
||||||
|
if (follow)
|
||||||
|
r = stat(path, &st);
|
||||||
|
else
|
||||||
|
r = lstat(path, &st);
|
||||||
|
if (r < 0)
|
||||||
|
return -errno;
|
||||||
|
|
||||||
|
return !!S_ISDIR(st.st_mode);
|
||||||
|
}
|
||||||
|
|
||||||
|
int is_device_node(const char *path) {
|
||||||
|
struct stat info;
|
||||||
|
|
||||||
|
assert(path);
|
||||||
|
|
||||||
|
if (lstat(path, &info) < 0)
|
||||||
|
return -errno;
|
||||||
|
|
||||||
|
return !!(S_ISBLK(info.st_mode) || S_ISCHR(info.st_mode));
|
||||||
|
}
|
||||||
|
|
||||||
|
int dir_is_empty(const char *path) {
|
||||||
|
_cleanup_closedir_ DIR *d;
|
||||||
|
struct dirent *de;
|
||||||
|
|
||||||
|
d = opendir(path);
|
||||||
|
if (!d)
|
||||||
|
return -errno;
|
||||||
|
|
||||||
|
FOREACH_DIRENT(de, d, return -errno)
|
||||||
|
return 0;
|
||||||
|
|
||||||
|
return 1;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool null_or_empty(struct stat *st) {
|
||||||
|
assert(st);
|
||||||
|
|
||||||
|
if (S_ISREG(st->st_mode) && st->st_size <= 0)
|
||||||
|
return true;
|
||||||
|
|
||||||
|
/* We don't want to hardcode the major/minor of /dev/null,
|
||||||
|
* hence we do a simpler "is this a device node?" check. */
|
||||||
|
|
||||||
|
if (S_ISCHR(st->st_mode) || S_ISBLK(st->st_mode))
|
||||||
|
return true;
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
int null_or_empty_path(const char *fn) {
|
||||||
|
struct stat st;
|
||||||
|
|
||||||
|
assert(fn);
|
||||||
|
|
||||||
|
if (stat(fn, &st) < 0)
|
||||||
|
return -errno;
|
||||||
|
|
||||||
|
return null_or_empty(&st);
|
||||||
|
}
|
||||||
|
|
||||||
|
int null_or_empty_fd(int fd) {
|
||||||
|
struct stat st;
|
||||||
|
|
||||||
|
assert(fd >= 0);
|
||||||
|
|
||||||
|
if (fstat(fd, &st) < 0)
|
||||||
|
return -errno;
|
||||||
|
|
||||||
|
return null_or_empty(&st);
|
||||||
|
}
|
||||||
|
|
||||||
|
int path_is_read_only_fs(const char *path) {
|
||||||
|
struct statvfs st;
|
||||||
|
|
||||||
|
assert(path);
|
||||||
|
|
||||||
|
if (statvfs(path, &st) < 0)
|
||||||
|
return -errno;
|
||||||
|
|
||||||
|
if (st.f_flag & ST_RDONLY)
|
||||||
|
return true;
|
||||||
|
|
||||||
|
/* On NFS, statvfs() might not reflect whether we can actually
|
||||||
|
* write to the remote share. Let's try again with
|
||||||
|
* access(W_OK) which is more reliable, at least sometimes. */
|
||||||
|
if (access(path, W_OK) < 0 && errno == EROFS)
|
||||||
|
return true;
|
||||||
|
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
|
||||||
|
int path_is_os_tree(const char *path) {
|
||||||
|
char *p;
|
||||||
|
int r;
|
||||||
|
|
||||||
|
assert(path);
|
||||||
|
|
||||||
|
/* We use /usr/lib/os-release as flag file if something is an OS */
|
||||||
|
p = strjoina(path, "/usr/lib/os-release");
|
||||||
|
r = access(p, F_OK);
|
||||||
|
if (r >= 0)
|
||||||
|
return 1;
|
||||||
|
|
||||||
|
/* Also check for the old location in /etc, just in case. */
|
||||||
|
p = strjoina(path, "/etc/os-release");
|
||||||
|
r = access(p, F_OK);
|
||||||
|
|
||||||
|
return r >= 0;
|
||||||
|
}
|
||||||
|
|
||||||
|
int files_same(const char *filea, const char *fileb) {
|
||||||
|
struct stat a, b;
|
||||||
|
|
||||||
|
assert(filea);
|
||||||
|
assert(fileb);
|
||||||
|
|
||||||
|
if (stat(filea, &a) < 0)
|
||||||
|
return -errno;
|
||||||
|
|
||||||
|
if (stat(fileb, &b) < 0)
|
||||||
|
return -errno;
|
||||||
|
|
||||||
|
return a.st_dev == b.st_dev &&
|
||||||
|
a.st_ino == b.st_ino;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool is_fs_type(const struct statfs *s, statfs_f_type_t magic_value) {
|
||||||
|
assert(s);
|
||||||
|
assert_cc(sizeof(statfs_f_type_t) >= sizeof(s->f_type));
|
||||||
|
|
||||||
|
return F_TYPE_EQUAL(s->f_type, magic_value);
|
||||||
|
}
|
||||||
|
|
||||||
|
int fd_check_fstype(int fd, statfs_f_type_t magic_value) {
|
||||||
|
struct statfs s;
|
||||||
|
|
||||||
|
if (fstatfs(fd, &s) < 0)
|
||||||
|
return -errno;
|
||||||
|
|
||||||
|
return is_fs_type(&s, magic_value);
|
||||||
|
}
|
||||||
|
|
||||||
|
int path_check_fstype(const char *path, statfs_f_type_t magic_value) {
|
||||||
|
_cleanup_close_ int fd = -1;
|
||||||
|
|
||||||
|
fd = open(path, O_RDONLY);
|
||||||
|
if (fd < 0)
|
||||||
|
return -errno;
|
||||||
|
|
||||||
|
return fd_check_fstype(fd, magic_value);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool is_temporary_fs(const struct statfs *s) {
|
||||||
|
return is_fs_type(s, TMPFS_MAGIC) ||
|
||||||
|
is_fs_type(s, RAMFS_MAGIC);
|
||||||
|
}
|
||||||
|
|
||||||
|
int fd_is_temporary_fs(int fd) {
|
||||||
|
struct statfs s;
|
||||||
|
|
||||||
|
if (fstatfs(fd, &s) < 0)
|
||||||
|
return -errno;
|
||||||
|
|
||||||
|
return is_temporary_fs(&s);
|
||||||
|
}
|
63
src/basic/stat-util.h
Normal file
63
src/basic/stat-util.h
Normal file
|
@ -0,0 +1,63 @@
|
||||||
|
/*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/
|
||||||
|
|
||||||
|
#pragma once
|
||||||
|
|
||||||
|
/***
|
||||||
|
This file is part of systemd.
|
||||||
|
|
||||||
|
Copyright 2010-2012 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 <stdbool.h>
|
||||||
|
#include <sys/stat.h>
|
||||||
|
#include <sys/vfs.h>
|
||||||
|
|
||||||
|
#include "macro.h"
|
||||||
|
|
||||||
|
int is_symlink(const char *path);
|
||||||
|
int is_dir(const char *path, bool follow);
|
||||||
|
int is_device_node(const char *path);
|
||||||
|
|
||||||
|
int dir_is_empty(const char *path);
|
||||||
|
|
||||||
|
static inline int dir_is_populated(const char *path) {
|
||||||
|
int r;
|
||||||
|
r = dir_is_empty(path);
|
||||||
|
if (r < 0)
|
||||||
|
return r;
|
||||||
|
return !r;
|
||||||
|
}
|
||||||
|
|
||||||
|
bool null_or_empty(struct stat *st) _pure_;
|
||||||
|
int null_or_empty_path(const char *fn);
|
||||||
|
int null_or_empty_fd(int fd);
|
||||||
|
|
||||||
|
int path_is_read_only_fs(const char *path);
|
||||||
|
int path_is_os_tree(const char *path);
|
||||||
|
|
||||||
|
int files_same(const char *filea, const char *fileb);
|
||||||
|
|
||||||
|
/* The .f_type field of struct statfs is really weird defined on
|
||||||
|
* different archs. Let's use our own type we know is sufficiently
|
||||||
|
* larger to store the possible values. */
|
||||||
|
typedef long statfs_f_type_t;
|
||||||
|
|
||||||
|
bool is_fs_type(const struct statfs *s, statfs_f_type_t magic_value) _pure_;
|
||||||
|
int fd_check_fstype(int fd, statfs_f_type_t magic_value);
|
||||||
|
int path_check_fstype(const char *path, statfs_f_type_t magic_value);
|
||||||
|
|
||||||
|
bool is_temporary_fs(const struct statfs *s) _pure_;
|
||||||
|
int fd_is_temporary_fs(int fd);
|
|
@ -39,6 +39,7 @@
|
||||||
#include "path-util.h"
|
#include "path-util.h"
|
||||||
#include "process-util.h"
|
#include "process-util.h"
|
||||||
#include "socket-util.h"
|
#include "socket-util.h"
|
||||||
|
#include "stat-util.h"
|
||||||
#include "string-util.h"
|
#include "string-util.h"
|
||||||
#include "terminal-util.h"
|
#include "terminal-util.h"
|
||||||
#include "time-util.h"
|
#include "time-util.h"
|
||||||
|
|
134
src/basic/util.c
134
src/basic/util.c
|
@ -102,6 +102,7 @@
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
#include "virt.h"
|
#include "virt.h"
|
||||||
#include "dirent-util.h"
|
#include "dirent-util.h"
|
||||||
|
#include "stat-util.h"
|
||||||
|
|
||||||
/* Put this test here for a lack of better place */
|
/* Put this test here for a lack of better place */
|
||||||
assert_cc(EAGAIN == EWOULDBLOCK);
|
assert_cc(EAGAIN == EWOULDBLOCK);
|
||||||
|
@ -146,20 +147,6 @@ bool fstype_is_network(const char *fstype) {
|
||||||
return nulstr_contains(table, fstype);
|
return nulstr_contains(table, fstype);
|
||||||
}
|
}
|
||||||
|
|
||||||
int dir_is_empty(const char *path) {
|
|
||||||
_cleanup_closedir_ DIR *d;
|
|
||||||
struct dirent *de;
|
|
||||||
|
|
||||||
d = opendir(path);
|
|
||||||
if (!d)
|
|
||||||
return -errno;
|
|
||||||
|
|
||||||
FOREACH_DIRENT(de, d, return -errno)
|
|
||||||
return 0;
|
|
||||||
|
|
||||||
return 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
void rename_process(const char name[8]) {
|
void rename_process(const char name[8]) {
|
||||||
assert(name);
|
assert(name);
|
||||||
|
|
||||||
|
@ -191,59 +178,6 @@ void rename_process(const char name[8]) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
bool is_fs_type(const struct statfs *s, statfs_f_type_t magic_value) {
|
|
||||||
assert(s);
|
|
||||||
assert_cc(sizeof(statfs_f_type_t) >= sizeof(s->f_type));
|
|
||||||
|
|
||||||
return F_TYPE_EQUAL(s->f_type, magic_value);
|
|
||||||
}
|
|
||||||
|
|
||||||
int fd_check_fstype(int fd, statfs_f_type_t magic_value) {
|
|
||||||
struct statfs s;
|
|
||||||
|
|
||||||
if (fstatfs(fd, &s) < 0)
|
|
||||||
return -errno;
|
|
||||||
|
|
||||||
return is_fs_type(&s, magic_value);
|
|
||||||
}
|
|
||||||
|
|
||||||
int path_check_fstype(const char *path, statfs_f_type_t magic_value) {
|
|
||||||
_cleanup_close_ int fd = -1;
|
|
||||||
|
|
||||||
fd = open(path, O_RDONLY);
|
|
||||||
if (fd < 0)
|
|
||||||
return -errno;
|
|
||||||
|
|
||||||
return fd_check_fstype(fd, magic_value);
|
|
||||||
}
|
|
||||||
|
|
||||||
bool is_temporary_fs(const struct statfs *s) {
|
|
||||||
return is_fs_type(s, TMPFS_MAGIC) ||
|
|
||||||
is_fs_type(s, RAMFS_MAGIC);
|
|
||||||
}
|
|
||||||
|
|
||||||
int fd_is_temporary_fs(int fd) {
|
|
||||||
struct statfs s;
|
|
||||||
|
|
||||||
if (fstatfs(fd, &s) < 0)
|
|
||||||
return -errno;
|
|
||||||
|
|
||||||
return is_temporary_fs(&s);
|
|
||||||
}
|
|
||||||
|
|
||||||
int files_same(const char *filea, const char *fileb) {
|
|
||||||
struct stat a, b;
|
|
||||||
|
|
||||||
if (stat(filea, &a) < 0)
|
|
||||||
return -errno;
|
|
||||||
|
|
||||||
if (stat(fileb, &b) < 0)
|
|
||||||
return -errno;
|
|
||||||
|
|
||||||
return a.st_dev == b.st_dev &&
|
|
||||||
a.st_ino == b.st_ino;
|
|
||||||
}
|
|
||||||
|
|
||||||
int running_in_chroot(void) {
|
int running_in_chroot(void) {
|
||||||
int ret;
|
int ret;
|
||||||
|
|
||||||
|
@ -265,40 +199,6 @@ noreturn void freeze(void) {
|
||||||
pause();
|
pause();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool null_or_empty(struct stat *st) {
|
|
||||||
assert(st);
|
|
||||||
|
|
||||||
if (S_ISREG(st->st_mode) && st->st_size <= 0)
|
|
||||||
return true;
|
|
||||||
|
|
||||||
if (S_ISCHR(st->st_mode) || S_ISBLK(st->st_mode))
|
|
||||||
return true;
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
|
|
||||||
int null_or_empty_path(const char *fn) {
|
|
||||||
struct stat st;
|
|
||||||
|
|
||||||
assert(fn);
|
|
||||||
|
|
||||||
if (stat(fn, &st) < 0)
|
|
||||||
return -errno;
|
|
||||||
|
|
||||||
return null_or_empty(&st);
|
|
||||||
}
|
|
||||||
|
|
||||||
int null_or_empty_fd(int fd) {
|
|
||||||
struct stat st;
|
|
||||||
|
|
||||||
assert(fd >= 0);
|
|
||||||
|
|
||||||
if (fstat(fd, &st) < 0)
|
|
||||||
return -errno;
|
|
||||||
|
|
||||||
return null_or_empty(&st);
|
|
||||||
}
|
|
||||||
|
|
||||||
static int do_execute(char **directories, usec_t timeout, char *argv[]) {
|
static int do_execute(char **directories, usec_t timeout, char *argv[]) {
|
||||||
_cleanup_hashmap_free_free_ Hashmap *pids = NULL;
|
_cleanup_hashmap_free_free_ Hashmap *pids = NULL;
|
||||||
_cleanup_set_free_free_ Set *seen = NULL;
|
_cleanup_set_free_free_ Set *seen = NULL;
|
||||||
|
@ -1508,38 +1408,6 @@ int update_reboot_param_file(const char *param) {
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int is_symlink(const char *path) {
|
|
||||||
struct stat info;
|
|
||||||
|
|
||||||
if (lstat(path, &info) < 0)
|
|
||||||
return -errno;
|
|
||||||
|
|
||||||
return !!S_ISLNK(info.st_mode);
|
|
||||||
}
|
|
||||||
|
|
||||||
int is_dir(const char* path, bool follow) {
|
|
||||||
struct stat st;
|
|
||||||
int r;
|
|
||||||
|
|
||||||
if (follow)
|
|
||||||
r = stat(path, &st);
|
|
||||||
else
|
|
||||||
r = lstat(path, &st);
|
|
||||||
if (r < 0)
|
|
||||||
return -errno;
|
|
||||||
|
|
||||||
return !!S_ISDIR(st.st_mode);
|
|
||||||
}
|
|
||||||
|
|
||||||
int is_device_node(const char *path) {
|
|
||||||
struct stat info;
|
|
||||||
|
|
||||||
if (lstat(path, &info) < 0)
|
|
||||||
return -errno;
|
|
||||||
|
|
||||||
return !!(S_ISBLK(info.st_mode) || S_ISCHR(info.st_mode));
|
|
||||||
}
|
|
||||||
|
|
||||||
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 a = 0, b = 0, c = 0;
|
int a = 0, b = 0, c = 0;
|
||||||
int k;
|
int k;
|
||||||
|
|
|
@ -141,39 +141,14 @@ ssize_t string_table_lookup(const char * const *table, size_t len, const char *k
|
||||||
|
|
||||||
bool fstype_is_network(const char *fstype);
|
bool fstype_is_network(const char *fstype);
|
||||||
|
|
||||||
int dir_is_empty(const char *path);
|
|
||||||
|
|
||||||
static inline int dir_is_populated(const char *path) {
|
|
||||||
int r;
|
|
||||||
r = dir_is_empty(path);
|
|
||||||
if (r < 0)
|
|
||||||
return r;
|
|
||||||
return !r;
|
|
||||||
}
|
|
||||||
|
|
||||||
typedef long statfs_f_type_t;
|
|
||||||
|
|
||||||
bool is_fs_type(const struct statfs *s, statfs_f_type_t magic_value) _pure_;
|
|
||||||
int fd_check_fstype(int fd, statfs_f_type_t magic_value);
|
|
||||||
int path_check_fstype(const char *path, statfs_f_type_t magic_value);
|
|
||||||
|
|
||||||
bool is_temporary_fs(const struct statfs *s) _pure_;
|
|
||||||
int fd_is_temporary_fs(int fd);
|
|
||||||
|
|
||||||
#define xsprintf(buf, fmt, ...) \
|
#define xsprintf(buf, fmt, ...) \
|
||||||
assert_message_se((size_t) snprintf(buf, ELEMENTSOF(buf), fmt, __VA_ARGS__) < ELEMENTSOF(buf), \
|
assert_message_se((size_t) snprintf(buf, ELEMENTSOF(buf), fmt, __VA_ARGS__) < ELEMENTSOF(buf), \
|
||||||
"xsprintf: " #buf "[] must be big enough")
|
"xsprintf: " #buf "[] must be big enough")
|
||||||
|
|
||||||
int files_same(const char *filea, const char *fileb);
|
|
||||||
|
|
||||||
int running_in_chroot(void);
|
int running_in_chroot(void);
|
||||||
|
|
||||||
noreturn void freeze(void);
|
noreturn void freeze(void);
|
||||||
|
|
||||||
bool null_or_empty(struct stat *st) _pure_;
|
|
||||||
int null_or_empty_path(const char *fn);
|
|
||||||
int null_or_empty_fd(int fd);
|
|
||||||
|
|
||||||
void execute_directories(const char* const* directories, usec_t timeout, char *argv[]);
|
void execute_directories(const char* const* directories, usec_t timeout, char *argv[]);
|
||||||
|
|
||||||
bool plymouth_running(void);
|
bool plymouth_running(void);
|
||||||
|
@ -452,10 +427,6 @@ union file_handle_union {
|
||||||
|
|
||||||
int update_reboot_param_file(const char *param);
|
int update_reboot_param_file(const char *param);
|
||||||
|
|
||||||
int is_symlink(const char *path);
|
|
||||||
int is_dir(const char *path, bool follow);
|
|
||||||
int is_device_node(const char *path);
|
|
||||||
|
|
||||||
#define INOTIFY_EVENT_MAX (sizeof(struct inotify_event) + NAME_MAX + 1)
|
#define INOTIFY_EVENT_MAX (sizeof(struct inotify_event) + NAME_MAX + 1)
|
||||||
|
|
||||||
#define FOREACH_INOTIFY_EVENT(e, buffer, sz) \
|
#define FOREACH_INOTIFY_EVENT(e, buffer, sz) \
|
||||||
|
|
|
@ -41,6 +41,7 @@
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
#include "path-util.h"
|
#include "path-util.h"
|
||||||
#include "selinux-access.h"
|
#include "selinux-access.h"
|
||||||
|
#include "stat-util.h"
|
||||||
#include "string-util.h"
|
#include "string-util.h"
|
||||||
#include "strv.h"
|
#include "strv.h"
|
||||||
#include "virt.h"
|
#include "virt.h"
|
||||||
|
|
|
@ -29,6 +29,7 @@
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
#include "parse-util.h"
|
#include "parse-util.h"
|
||||||
#include "path-util.h"
|
#include "path-util.h"
|
||||||
|
#include "stat-util.h"
|
||||||
#include "string-util.h"
|
#include "string-util.h"
|
||||||
#include "swap.h"
|
#include "swap.h"
|
||||||
#include "udev-util.h"
|
#include "udev-util.h"
|
||||||
|
|
|
@ -56,6 +56,7 @@
|
||||||
#endif
|
#endif
|
||||||
#include "securebits.h"
|
#include "securebits.h"
|
||||||
#include "signal-util.h"
|
#include "signal-util.h"
|
||||||
|
#include "stat-util.h"
|
||||||
#include "string-util.h"
|
#include "string-util.h"
|
||||||
#include "strv.h"
|
#include "strv.h"
|
||||||
#include "unit-name.h"
|
#include "unit-name.h"
|
||||||
|
|
|
@ -41,6 +41,7 @@
|
||||||
#include "mount-util.h"
|
#include "mount-util.h"
|
||||||
#include "path-util.h"
|
#include "path-util.h"
|
||||||
#include "process-util.h"
|
#include "process-util.h"
|
||||||
|
#include "stat-util.h"
|
||||||
#include "string-util.h"
|
#include "string-util.h"
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
#include "virt.h"
|
#include "virt.h"
|
||||||
|
|
|
@ -76,6 +76,7 @@
|
||||||
#include "signal-util.h"
|
#include "signal-util.h"
|
||||||
#include "smack-setup.h"
|
#include "smack-setup.h"
|
||||||
#include "special.h"
|
#include "special.h"
|
||||||
|
#include "stat-util.h"
|
||||||
#include "strv.h"
|
#include "strv.h"
|
||||||
#include "switch-root.h"
|
#include "switch-root.h"
|
||||||
#include "terminal-util.h"
|
#include "terminal-util.h"
|
||||||
|
|
|
@ -72,6 +72,7 @@
|
||||||
#include "rm-rf.h"
|
#include "rm-rf.h"
|
||||||
#include "signal-util.h"
|
#include "signal-util.h"
|
||||||
#include "special.h"
|
#include "special.h"
|
||||||
|
#include "stat-util.h"
|
||||||
#include "string-util.h"
|
#include "string-util.h"
|
||||||
#include "strv.h"
|
#include "strv.h"
|
||||||
#include "terminal-util.h"
|
#include "terminal-util.h"
|
||||||
|
|
|
@ -32,6 +32,7 @@
|
||||||
#include "mkdir.h"
|
#include "mkdir.h"
|
||||||
#include "path.h"
|
#include "path.h"
|
||||||
#include "special.h"
|
#include "special.h"
|
||||||
|
#include "stat-util.h"
|
||||||
#include "string-util.h"
|
#include "string-util.h"
|
||||||
#include "unit-name.h"
|
#include "unit-name.h"
|
||||||
#include "unit.h"
|
#include "unit.h"
|
||||||
|
|
|
@ -49,6 +49,7 @@
|
||||||
#include "process-util.h"
|
#include "process-util.h"
|
||||||
#include "set.h"
|
#include "set.h"
|
||||||
#include "special.h"
|
#include "special.h"
|
||||||
|
#include "stat-util.h"
|
||||||
#include "string-util.h"
|
#include "string-util.h"
|
||||||
#include "strv.h"
|
#include "strv.h"
|
||||||
#include "unit-name.h"
|
#include "unit-name.h"
|
||||||
|
|
|
@ -36,6 +36,7 @@
|
||||||
#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 "stat-util.h"
|
||||||
#include "string-util.h"
|
#include "string-util.h"
|
||||||
#include "strv.h"
|
#include "strv.h"
|
||||||
#include "terminal-util.h"
|
#include "terminal-util.h"
|
||||||
|
|
|
@ -36,6 +36,7 @@
|
||||||
#include "parse-util.h"
|
#include "parse-util.h"
|
||||||
#include "path-util.h"
|
#include "path-util.h"
|
||||||
#include "special.h"
|
#include "special.h"
|
||||||
|
#include "stat-util.h"
|
||||||
#include "string-util.h"
|
#include "string-util.h"
|
||||||
#include "strv.h"
|
#include "strv.h"
|
||||||
#include "unit-name.h"
|
#include "unit-name.h"
|
||||||
|
|
|
@ -42,6 +42,7 @@
|
||||||
#include "parse-util.h"
|
#include "parse-util.h"
|
||||||
#include "path-util.h"
|
#include "path-util.h"
|
||||||
#include "special.h"
|
#include "special.h"
|
||||||
|
#include "stat-util.h"
|
||||||
#include "string-util.h"
|
#include "string-util.h"
|
||||||
#include "udev-util.h"
|
#include "udev-util.h"
|
||||||
#include "unit-name.h"
|
#include "unit-name.h"
|
||||||
|
|
|
@ -47,6 +47,7 @@
|
||||||
#include "parse-util.h"
|
#include "parse-util.h"
|
||||||
#include "signal-util.h"
|
#include "signal-util.h"
|
||||||
#include "socket-util.h"
|
#include "socket-util.h"
|
||||||
|
#include "stat-util.h"
|
||||||
#include "string-util.h"
|
#include "string-util.h"
|
||||||
#include "strv.h"
|
#include "strv.h"
|
||||||
|
|
||||||
|
|
|
@ -35,6 +35,7 @@
|
||||||
#include "parse-util.h"
|
#include "parse-util.h"
|
||||||
#include "path-util.h"
|
#include "path-util.h"
|
||||||
#include "set.h"
|
#include "set.h"
|
||||||
|
#include "stat-util.h"
|
||||||
#include "string-util.h"
|
#include "string-util.h"
|
||||||
#include "strv.h"
|
#include "strv.h"
|
||||||
#include "strxcpyx.h"
|
#include "strxcpyx.h"
|
||||||
|
|
|
@ -30,6 +30,7 @@
|
||||||
#include "networkd-netdev.h"
|
#include "networkd-netdev.h"
|
||||||
#include "networkd.h"
|
#include "networkd.h"
|
||||||
#include "siphash24.h"
|
#include "siphash24.h"
|
||||||
|
#include "stat-util.h"
|
||||||
#include "string-util.h"
|
#include "string-util.h"
|
||||||
|
|
||||||
const NetDevVTable * const netdev_vtable[_NETDEV_KIND_MAX] = {
|
const NetDevVTable * const netdev_vtable[_NETDEV_KIND_MAX] = {
|
||||||
|
|
|
@ -31,6 +31,7 @@
|
||||||
#include "networkd-network.h"
|
#include "networkd-network.h"
|
||||||
#include "networkd.h"
|
#include "networkd.h"
|
||||||
#include "parse-util.h"
|
#include "parse-util.h"
|
||||||
|
#include "stat-util.h"
|
||||||
#include "string-util.h"
|
#include "string-util.h"
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
|
|
||||||
|
|
|
@ -33,6 +33,7 @@
|
||||||
#include "path-util.h"
|
#include "path-util.h"
|
||||||
#include "rm-rf.h"
|
#include "rm-rf.h"
|
||||||
#include "set.h"
|
#include "set.h"
|
||||||
|
#include "stat-util.h"
|
||||||
#include "string-util.h"
|
#include "string-util.h"
|
||||||
#include "strv.h"
|
#include "strv.h"
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
|
|
|
@ -21,12 +21,12 @@
|
||||||
|
|
||||||
#include "sd-bus.h"
|
#include "sd-bus.h"
|
||||||
|
|
||||||
#include "util.h"
|
|
||||||
#include "strv.h"
|
|
||||||
#include "bus-util.h"
|
|
||||||
#include "bus-error.h"
|
#include "bus-error.h"
|
||||||
|
#include "bus-util.h"
|
||||||
#include "nspawn-register.h"
|
#include "nspawn-register.h"
|
||||||
|
#include "stat-util.h"
|
||||||
|
#include "strv.h"
|
||||||
|
#include "util.h"
|
||||||
|
|
||||||
int register_machine(
|
int register_machine(
|
||||||
const char *machine_name,
|
const char *machine_name,
|
||||||
|
|
|
@ -90,6 +90,7 @@
|
||||||
#endif
|
#endif
|
||||||
#include "signal-util.h"
|
#include "signal-util.h"
|
||||||
#include "socket-util.h"
|
#include "socket-util.h"
|
||||||
|
#include "stat-util.h"
|
||||||
#include "string-util.h"
|
#include "string-util.h"
|
||||||
#include "strv.h"
|
#include "strv.h"
|
||||||
#include "terminal-util.h"
|
#include "terminal-util.h"
|
||||||
|
|
|
@ -41,6 +41,7 @@
|
||||||
#include "path-util.h"
|
#include "path-util.h"
|
||||||
#include "selinux-util.h"
|
#include "selinux-util.h"
|
||||||
#include "smack-util.h"
|
#include "smack-util.h"
|
||||||
|
#include "stat-util.h"
|
||||||
#include "string-util.h"
|
#include "string-util.h"
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
#include "virt.h"
|
#include "virt.h"
|
||||||
|
|
|
@ -38,6 +38,7 @@
|
||||||
#include "path-util.h"
|
#include "path-util.h"
|
||||||
#include "set.h"
|
#include "set.h"
|
||||||
#include "special.h"
|
#include "special.h"
|
||||||
|
#include "stat-util.h"
|
||||||
#include "string-util.h"
|
#include "string-util.h"
|
||||||
#include "strv.h"
|
#include "strv.h"
|
||||||
#include "unit-name.h"
|
#include "unit-name.h"
|
||||||
|
|
|
@ -36,6 +36,7 @@
|
||||||
#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 "stat-util.h"
|
||||||
#include "string-util.h"
|
#include "string-util.h"
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
|
|
||||||
|
|
|
@ -73,6 +73,7 @@
|
||||||
#include "spawn-ask-password-agent.h"
|
#include "spawn-ask-password-agent.h"
|
||||||
#include "spawn-polkit-agent.h"
|
#include "spawn-polkit-agent.h"
|
||||||
#include "special.h"
|
#include "special.h"
|
||||||
|
#include "stat-util.h"
|
||||||
#include "strv.h"
|
#include "strv.h"
|
||||||
#include "terminal-util.h"
|
#include "terminal-util.h"
|
||||||
#include "unit-name.h"
|
#include "unit-name.h"
|
||||||
|
|
|
@ -27,14 +27,15 @@
|
||||||
|
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
#include "hashmap.h"
|
#include "hashmap.h"
|
||||||
|
#include "hexdecoct.h"
|
||||||
#include "install.h"
|
#include "install.h"
|
||||||
#include "log.h"
|
#include "log.h"
|
||||||
#include "mkdir.h"
|
#include "mkdir.h"
|
||||||
#include "hexdecoct.h"
|
|
||||||
#include "path-lookup.h"
|
#include "path-lookup.h"
|
||||||
#include "path-util.h"
|
#include "path-util.h"
|
||||||
#include "set.h"
|
#include "set.h"
|
||||||
#include "special.h"
|
#include "special.h"
|
||||||
|
#include "stat-util.h"
|
||||||
#include "string-util.h"
|
#include "string-util.h"
|
||||||
#include "strv.h"
|
#include "strv.h"
|
||||||
#include "unit-name.h"
|
#include "unit-name.h"
|
||||||
|
|
|
@ -47,6 +47,7 @@
|
||||||
#include "process-util.h"
|
#include "process-util.h"
|
||||||
#include "rm-rf.h"
|
#include "rm-rf.h"
|
||||||
#include "signal-util.h"
|
#include "signal-util.h"
|
||||||
|
#include "stat-util.h"
|
||||||
#include "string-util.h"
|
#include "string-util.h"
|
||||||
#include "strv.h"
|
#include "strv.h"
|
||||||
#include "user-util.h"
|
#include "user-util.h"
|
||||||
|
|
|
@ -61,6 +61,7 @@
|
||||||
#include "selinux-util.h"
|
#include "selinux-util.h"
|
||||||
#include "set.h"
|
#include "set.h"
|
||||||
#include "specifier.h"
|
#include "specifier.h"
|
||||||
|
#include "stat-util.h"
|
||||||
#include "string-util.h"
|
#include "string-util.h"
|
||||||
#include "strv.h"
|
#include "strv.h"
|
||||||
#include "user-util.h"
|
#include "user-util.h"
|
||||||
|
|
|
@ -37,6 +37,7 @@
|
||||||
#include "parse-util.h"
|
#include "parse-util.h"
|
||||||
#include "path-util.h"
|
#include "path-util.h"
|
||||||
#include "random-util.h"
|
#include "random-util.h"
|
||||||
|
#include "stat-util.h"
|
||||||
#include "string-util.h"
|
#include "string-util.h"
|
||||||
#include "strv.h"
|
#include "strv.h"
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
|
|
|
@ -33,6 +33,7 @@
|
||||||
#include "escape.h"
|
#include "escape.h"
|
||||||
#include "fd-util.h"
|
#include "fd-util.h"
|
||||||
#include "path-util.h"
|
#include "path-util.h"
|
||||||
|
#include "stat-util.h"
|
||||||
#include "strbuf.h"
|
#include "strbuf.h"
|
||||||
#include "string-util.h"
|
#include "string-util.h"
|
||||||
#include "strv.h"
|
#include "strv.h"
|
||||||
|
|
Loading…
Reference in a new issue