]> git.ipfire.org Git - thirdparty/systemd.git/blame - src/basic/path-util.h
networkd: remote checksum offload for vxlan (#4110)
[thirdparty/systemd.git] / src / basic / path-util.h
CommitLineData
76877b46 1#pragma once
9eb977db
KS
2
3/***
4 This file is part of systemd.
5
6 Copyright 2010-2012 Lennart Poettering
7
8 systemd is free software; you can redistribute it and/or modify it
9 under the terms of the GNU Lesser General Public License as published by
10 the Free Software Foundation; either version 2.1 of the License, or
11 (at your option) any later version.
12
13 systemd is distributed in the hope that it will be useful, but
14 WITHOUT ANY WARRANTY; without even the implied warranty of
15 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
16 Lesser General Public License for more details.
17
18 You should have received a copy of the GNU Lesser General Public License
19 along with systemd; If not, see <http://www.gnu.org/licenses/>.
20***/
21
11c3a366 22#include <alloca.h>
44a6b1b6 23#include <stdbool.h>
11c3a366 24#include <stddef.h>
9eb977db 25
44a6b1b6 26#include "macro.h"
8e184852 27#include "time-util.h"
44a6b1b6 28
e10a55fd
SL
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
c9d954b2 32#ifdef HAVE_SPLIT_USR
e10a55fd 33# define DEFAULT_PATH DEFAULT_PATH_SPLIT_USR
c9d954b2 34#else
e10a55fd 35# define DEFAULT_PATH DEFAULT_PATH_NORMAL
c9d954b2
ZJS
36#endif
37
44a6b1b6 38bool is_path(const char *p) _pure_;
0f474365 39int path_split_and_make_absolute(const char *p, char ***ret);
44a6b1b6
ZJS
40bool path_is_absolute(const char *p) _pure_;
41char* path_make_absolute(const char *p, const char *prefix);
0f474365 42int path_make_absolute_cwd(const char *p, char **ret);
7cb9c51c 43int path_make_relative(const char *from_dir, const char *to_path, char **_r);
44a6b1b6
ZJS
44char* path_kill_slashes(char *path);
45char* path_startswith(const char *path, const char *prefix) _pure_;
2230852b 46int path_compare(const char *a, const char *b) _pure_;
44a6b1b6 47bool path_equal(const char *a, const char *b) _pure_;
c78e47a6 48bool path_equal_or_files_same(const char *a, const char *b);
0c6ea3a4 49char* path_join(const char *root, const char *path, const char *rest);
44a6b1b6 50
24737c29
ZJS
51static inline bool path_equal_ptr(const char *a, const char *b) {
52 return !!a == !!b && (!a || path_equal(a, b));
53}
54
3ae5990c
ZJS
55/* Note: the search terminates on the first NULL item. */
56#define PATH_IN_SET(p, ...) \
57 ({ \
58 char **s; \
59 bool _found = false; \
60 STRV_FOREACH(s, STRV_MAKE(__VA_ARGS__)) \
61 if (path_equal(p, *s)) { \
62 _found = true; \
63 break; \
64 } \
65 _found; \
66 })
67
0f474365 68int path_strv_make_absolute_cwd(char **l);
7d8da2c9
MM
69char** path_strv_resolve(char **l, const char *prefix);
70char** path_strv_resolve_uniq(char **l, const char *prefix);
9eb977db 71
85eca92e 72int find_binary(const char *name, char **filename);
fecffe5d 73
2ad8416d 74bool paths_check_timestamp(const char* const* paths, usec_t *paths_ts_usec, bool update);
8e184852 75
eb66db55 76int fsck_exists(const char *fstype);
5bcd08db 77int mkfs_exists(const char *fstype);
eb66db55 78
e203f7c3
LP
79/* Iterates through the path prefixes of the specified path, going up
80 * the tree, to root. Also returns "" (and not "/"!) for the root
81 * directory. Excludes the specified directory itself */
fecffe5d 82#define PATH_FOREACH_PREFIX(prefix, path) \
4a690c47 83 for (char *_slash = ({ path_kill_slashes(strcpy(prefix, path)); streq(prefix, "/") ? NULL : strrchr(prefix, '/'); }); _slash && ((*_slash = 0), true); _slash = strrchr((prefix), '/'))
e203f7c3
LP
84
85/* Same as PATH_FOREACH_PREFIX but also includes the specified path itself */
86#define PATH_FOREACH_PREFIX_MORE(prefix, path) \
4a690c47 87 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), '/'))
1d13f648
LP
88
89char *prefix_root(const char *root, const char *path);
90
91/* Similar to prefix_root(), but returns an alloca() buffer, or
92 * possibly a const pointer into the path parameter */
93#define prefix_roota(root, path) \
94 ({ \
95 const char* _path = (path), *_root = (root), *_ret; \
96 char *_p, *_n; \
97 size_t _l; \
98 while (_path[0] == '/' && _path[1] == '/') \
99 _path ++; \
100 if (isempty(_root) || path_equal(_root, "/")) \
101 _ret = _path; \
102 else { \
103 _l = strlen(_root) + 1 + strlen(_path) + 1; \
104 _n = alloca(_l); \
105 _p = stpcpy(_n, _root); \
106 while (_p > _n && _p[-1] == '/') \
107 _p--; \
108 if (_path[0] != '/') \
109 *(_p++) = '/'; \
110 strcpy(_p, _path); \
111 _ret = _n; \
112 } \
113 _ret; \
114 })
0f03c2a4
LP
115
116int parse_path_argument_and_warn(const char *path, bool suppress_root, char **arg);
5f311f8c
LP
117
118char* dirname_malloc(const char *path);
bb15fafe
LP
119
120bool filename_is_valid(const char *p) _pure_;
121bool path_is_safe(const char *p) _pure_;
a0956174
LP
122
123char *file_in_same_dir(const char *path, const char *filename);
124
55cdd057 125bool hidden_or_backup_file(const char *filename) _pure_;
a0956174
LP
126
127bool is_device_path(const char *path);