chiark / gitweb /
Add support for building elogind against musl libc
[elogind.git] / src / basic / path-util.h
1 /*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/
2
3 #pragma once
4
5 /***
6   This file is part of systemd.
7
8   Copyright 2010-2012 Lennart Poettering
9
10   systemd is free software; you can redistribute it and/or modify it
11   under the terms of the GNU Lesser General Public License as published by
12   the Free Software Foundation; either version 2.1 of the License, or
13   (at your option) any later version.
14
15   systemd is distributed in the hope that it will be useful, but
16   WITHOUT ANY WARRANTY; without even the implied warranty of
17   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
18   Lesser General Public License for more details.
19
20   You should have received a copy of the GNU Lesser General Public License
21   along with systemd; If not, see <http://www.gnu.org/licenses/>.
22 ***/
23
24 #include <stdbool.h>
25
26 #include "macro.h"
27 #include "time-util.h"
28
29 #define DEFAULT_PATH_NORMAL "/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin"
30 #define DEFAULT_PATH_SPLIT_USR DEFAULT_PATH_NORMAL ":/sbin:/bin"
31
32 #ifdef HAVE_SPLIT_USR
33 #  define DEFAULT_PATH DEFAULT_PATH_SPLIT_USR
34 #else
35 #  define DEFAULT_PATH DEFAULT_PATH_NORMAL
36 #endif
37
38 bool is_path(const char *p) _pure_;
39 // UNNEEDED char** path_split_and_make_absolute(const char *p);
40 int path_get_parent(const char *path, char **parent);
41 bool path_is_absolute(const char *p) _pure_;
42 char* path_make_absolute(const char *p, const char *prefix);
43 char* path_make_absolute_cwd(const char *p);
44 // UNNEEDED int path_make_relative(const char *from_dir, const char *to_path, char **_r);
45 char* path_kill_slashes(char *path);
46 char* path_startswith(const char *path, const char *prefix) _pure_;
47 int path_compare(const char *a, const char *b) _pure_;
48 bool path_equal(const char *a, const char *b) _pure_;
49 // UNNEEDED bool path_equal_or_files_same(const char *a, const char *b);
50 // UNNEEDED char* path_join(const char *root, const char *path, const char *rest);
51
52 char** path_strv_make_absolute_cwd(char **l);
53 char** path_strv_resolve(char **l, const char *prefix);
54 char** path_strv_resolve_uniq(char **l, const char *prefix);
55
56 int fd_is_mount_point(int fd, const char *filename, int flags);
57 int path_is_mount_point(const char *path, int flags);
58 int path_is_read_only_fs(const char *path);
59 // UNNEEDED int path_is_os_tree(const char *path);
60
61 // UNNEEDED int find_binary(const char *name, bool local, char **filename);
62
63 // UNNEEDED bool paths_check_timestamp(const char* const* paths, usec_t *paths_ts_usec, bool update);
64
65 // UNNEEDED int fsck_exists(const char *fstype);
66
67 /* Iterates through the path prefixes of the specified path, going up
68  * the tree, to root. Also returns "" (and not "/"!) for the root
69  * directory. Excludes the specified directory itself */
70 #define PATH_FOREACH_PREFIX(prefix, path) \
71         for (char *_slash = ({ path_kill_slashes(strcpy(prefix, path)); streq(prefix, "/") ? NULL : strrchr(prefix, '/'); }); _slash && ((*_slash = 0), true); _slash = strrchr((prefix), '/'))
72
73 /* Same as PATH_FOREACH_PREFIX but also includes the specified path itself */
74 #define PATH_FOREACH_PREFIX_MORE(prefix, path) \
75         for (char *_slash = ({ path_kill_slashes(strcpy(prefix, path)); if (streq(prefix, "/")) prefix[0] = 0; strrchr(prefix, 0); }); _slash && ((*_slash = 0), true); _slash = strrchr((prefix), '/'))
76
77 // UNNEEDED char *prefix_root(const char *root, const char *path);
78
79 /* Similar to prefix_root(), but returns an alloca() buffer, or
80  * possibly a const pointer into the path parameter */
81 #define prefix_roota(root, path)                                        \
82         ({                                                              \
83                 const char* _path = (path), *_root = (root), *_ret;     \
84                 char *_p, *_n;                                          \
85                 size_t _l;                                              \
86                 while (_path[0] == '/' && _path[1] == '/')              \
87                         _path ++;                                       \
88                 if (isempty(_root) || path_equal(_root, "/"))           \
89                         _ret = _path;                                   \
90                 else {                                                  \
91                         _l = strlen(_root) + 1 + strlen(_path) + 1;     \
92                         _n = alloca(_l);                                \
93                         _p = stpcpy(_n, _root);                         \
94                         while (_p > _n && _p[-1] == '/')                \
95                                 _p--;                                   \
96                         if (_path[0] != '/')                            \
97                                 *(_p++) = '/';                          \
98                         strcpy(_p, _path);                              \
99                         _ret = _n;                                      \
100                 }                                                       \
101                 _ret;                                                   \
102         })