return conf_files_list_strv_internal(strv, suffix, root, flags, copy);
}
-int conf_files_list(char ***strv, const char *suffix, const char *root, unsigned flags, const char *dir, ...) {
+int conf_files_list(char ***strv, const char *suffix, const char *root, unsigned flags, const char *dir) {
_cleanup_strv_free_ char **dirs = NULL;
- va_list ap;
assert(strv);
- va_start(ap, dir);
- dirs = strv_new_ap(dir, ap);
- va_end(ap);
-
+ dirs = strv_new(dir);
if (!dirs)
return -ENOMEM;
CONF_FILES_FILTER_MASKED = 1 << 4,
};
-int conf_files_list(char ***ret, const char *suffix, const char *root, unsigned flags, const char *dir, ...) _sentinel_;
+int conf_files_list(char ***ret, const char *suffix, const char *root, unsigned flags, const char *dir);
int conf_files_list_strv(char ***ret, const char *suffix, const char *root, unsigned flags, const char* const* dirs);
int conf_files_list_nulstr(char ***ret, const char *suffix, const char *root, unsigned flags, const char *dirs);
int conf_files_insert(char ***strv, const char *root, char **dirs, const char *path);
static void test_conf_files_list(bool use_root) {
char tmp_dir[] = "/tmp/test-conf-files-XXXXXX";
_cleanup_strv_free_ char **found_files = NULL, **found_files2 = NULL;
- const char *root_dir, *search_1, *search_2, *expect_a, *expect_b, *expect_c, *mask;
+ const char *root_dir, *search, *expect_a, *expect_b, *expect_c, *mask;
- log_debug("/* %s(%s) */", __func__, yes_no(use_root));
+ log_info("/* %s(%s) */", __func__, yes_no(use_root));
setup_test_dir(tmp_dir,
- "/dir1/a.conf",
- "/dir2/a.conf",
- "/dir2/b.conf",
- "/dir2/c.foo",
- "/dir2/d.conf",
+ "/dir/a.conf",
+ "/dir/b.conf",
+ "/dir/c.foo",
NULL);
- mask = strjoina(tmp_dir, "/dir1/d.conf");
+ mask = strjoina(tmp_dir, "/dir/d.conf");
assert_se(symlink("/dev/null", mask) >= 0);
if (use_root) {
root_dir = tmp_dir;
- search_1 = "/dir1";
- search_2 = "/dir2";
+ search = "/dir";
} else {
root_dir = NULL;
- search_1 = strjoina(tmp_dir, "/dir1");
- search_2 = strjoina(tmp_dir, "/dir2");
+ search = strjoina(tmp_dir, "/dir");
}
- expect_a = strjoina(tmp_dir, "/dir1/a.conf");
- expect_b = strjoina(tmp_dir, "/dir2/b.conf");
- expect_c = strjoina(tmp_dir, "/dir2/c.foo");
+ expect_a = strjoina(tmp_dir, "/dir/a.conf");
+ expect_b = strjoina(tmp_dir, "/dir/b.conf");
+ expect_c = strjoina(tmp_dir, "/dir/c.foo");
log_debug("/* Check when filtered by suffix */");
- assert_se(conf_files_list(&found_files, ".conf", root_dir, CONF_FILES_FILTER_MASKED, search_1, search_2, NULL) == 0);
+ assert_se(conf_files_list(&found_files, ".conf", root_dir, CONF_FILES_FILTER_MASKED, search) == 0);
strv_print(found_files);
assert_se(found_files);
assert_se(!found_files[2]);
log_debug("/* Check when unfiltered */");
- assert_se(conf_files_list(&found_files2, NULL, root_dir, CONF_FILES_FILTER_MASKED, search_1, search_2, NULL) == 0);
+ assert_se(conf_files_list(&found_files2, NULL, root_dir, CONF_FILES_FILTER_MASKED, search) == 0);
strv_print(found_files2);
assert_se(found_files2);