diff options
author | Mike Yuan <me@yhndnzj.com> | 2024-09-14 19:02:32 +0200 |
---|---|---|
committer | Mike Yuan <me@yhndnzj.com> | 2024-10-06 19:42:39 +0200 |
commit | 1f8eedba9d9b2c81455c788d0edca2146d5f30a4 (patch) | |
tree | 90dc45e58ee70d376e6e43765d614928051d2637 /src/tmpfiles/tmpfiles.c | |
parent | path-lookup: assert that LOOKUP_PATHS_{EXCLUDE,TEMPORARY}_GENERATED are not u... (diff) | |
download | systemd-1f8eedba9d9b2c81455c788d0edca2146d5f30a4.tar.xz systemd-1f8eedba9d9b2c81455c788d0edca2146d5f30a4.zip |
path-lookup: introduce user_search_dirs() (shall replace xdg_user_dirs())
xdg_user_dirs() doesn't seem well-organized currently.
In all other xdg_user_*() funcs we assume /etc/xdg/systemd
to be a symlink to /etc/systemd/, hence it is the odd one out.
Also, when the relevant envvar is unset, it only returns
the global search dirs.
sd_path_lookup() actually covers this nicely with SD_PATH_SEARCH_*,
where the combined search paths (from user home and system) are used.
Therefore, let's introduce a wrapper for that, and deprecate xdg_user_dirs()
(would be removed in later commits).
Diffstat (limited to '')
-rw-r--r-- | src/tmpfiles/tmpfiles.c | 34 |
1 files changed, 10 insertions, 24 deletions
diff --git a/src/tmpfiles/tmpfiles.c b/src/tmpfiles/tmpfiles.c index 25403325e7..421e465d71 100644 --- a/src/tmpfiles/tmpfiles.c +++ b/src/tmpfiles/tmpfiles.c @@ -349,49 +349,35 @@ static int log_unresolvable_specifier(const char *filename, unsigned line) { arg_dry_run ? (would) : (doing), \ __VA_ARGS__) -static int user_config_paths(char*** ret) { +static int user_config_paths(char ***ret) { _cleanup_strv_free_ char **config_dirs = NULL, **data_dirs = NULL; - _cleanup_free_ char *persistent_config = NULL, *runtime_config = NULL, *data_home = NULL; - _cleanup_strv_free_ char **res = NULL; + _cleanup_free_ char *runtime_config = NULL; int r; - r = xdg_user_dirs(&config_dirs, &data_dirs); - if (r < 0) - return r; + assert(ret); - r = xdg_user_config_dir("/user-tmpfiles.d", &persistent_config); - if (r < 0 && !ERRNO_IS_NEG_NOINFO(r)) + /* Combined user-specific and global dirs */ + r = user_search_dirs("/user-tmpfiles.d", &config_dirs, &data_dirs); + if (r < 0) return r; r = xdg_user_runtime_dir("/user-tmpfiles.d", &runtime_config); if (r < 0 && !ERRNO_IS_NEG_NOINFO(r)) return r; - r = xdg_user_data_dir("/user-tmpfiles.d", &data_home); - if (r < 0 && !ERRNO_IS_NEG_NOINFO(r)) - return r; - - r = strv_extend_strv_concat(&res, (const char* const*) config_dirs, "/user-tmpfiles.d"); - if (r < 0) - return r; - - r = strv_extend_many( - &res, - persistent_config, - runtime_config, - data_home); + r = strv_consume(&config_dirs, TAKE_PTR(runtime_config)); if (r < 0) return r; - r = strv_extend_strv_concat(&res, (const char* const*) data_dirs, "/user-tmpfiles.d"); + r = strv_extend_strv_consume(&config_dirs, TAKE_PTR(data_dirs), /* filter_duplicates = */ true); if (r < 0) return r; - r = path_strv_make_absolute_cwd(res); + r = path_strv_make_absolute_cwd(config_dirs); if (r < 0) return r; - *ret = TAKE_PTR(res); + *ret = TAKE_PTR(config_dirs); return 0; } |