1
1
mirror of https://github.com/systemd/systemd-stable.git synced 2024-12-25 23:21:33 +03:00

strv: declare iterator of FOREACH_STRING() in the loop

Same idea as 03677889f0.

No functional change intended. The type of the iterator is generally changed to
be 'const char*' instead of 'char*'. Despite the type commonly used, modifying
the string was not allowed.

I adjusted the naming of some short variables for clarity and reduced the scope
of some variable declarations in code that was being touched anyway.
This commit is contained in:
Zbigniew Jędrzejewski-Szmek 2022-03-23 10:48:13 +01:00
parent 5b39139582
commit 5980d46304
53 changed files with 66 additions and 146 deletions

View File

@ -123,7 +123,6 @@ static int open_sockets(int *epoll_fd, bool accept) {
static int exec_process(const char *name, char **argv, int start_fd, size_t n_fds) { static int exec_process(const char *name, char **argv, int start_fd, size_t n_fds) {
_cleanup_strv_free_ char **envp = NULL; _cleanup_strv_free_ char **envp = NULL;
const char *var;
int r; int r;
if (arg_inetd && n_fds != 1) if (arg_inetd && n_fds != 1)

View File

@ -570,7 +570,6 @@ int get_files_in_directory(const char *path, char ***list) {
} }
static int getenv_tmp_dir(const char **ret_path) { static int getenv_tmp_dir(const char **ret_path) {
const char *n;
int r, ret = 0; int r, ret = 0;
assert(ret_path); assert(ret_path);

View File

@ -170,8 +170,6 @@ int open_extension_release(const char *root, const char *extension, char **ret_p
} }
} }
} else { } else {
const char *p;
FOREACH_STRING(p, "/etc/os-release", "/usr/lib/os-release") { FOREACH_STRING(p, "/etc/os-release", "/usr/lib/os-release") {
r = chase_symlinks(p, root, CHASE_PREFIX_ROOT, r = chase_symlinks(p, root, CHASE_PREFIX_ROOT,
ret_path ? &q : NULL, ret_path ? &q : NULL,

View File

@ -218,7 +218,7 @@ void strv_print(char * const *l);
}) })
#define _FOREACH_STRING(uniq, x, y, ...) \ #define _FOREACH_STRING(uniq, x, y, ...) \
for (char **UNIQ_T(l, uniq) = STRV_MAKE(({ x = y; }), ##__VA_ARGS__); \ for (const char *x, * const*UNIQ_T(l, uniq) = STRV_MAKE_CONST(({ x = y; }), ##__VA_ARGS__); \
x; \ x; \
x = *(++UNIQ_T(l, uniq))) x = *(++UNIQ_T(l, uniq)))

View File

@ -236,7 +236,6 @@ bool lookup_paths_timestamp_hash_same(const LookupPaths *lp, uint64_t timestamp_
} }
static int directory_name_is_valid(const char *name) { static int directory_name_is_valid(const char *name) {
const char *suffix;
/* Accept a directory whose name is a valid unit file name ending in .wants/, .requires/ or .d/ */ /* Accept a directory whose name is a valid unit file name ending in .wants/, .requires/ or .d/ */

View File

@ -1255,12 +1255,11 @@ static int remove_variables(sd_id128_t uuid, const char *path, bool in_order) {
} }
static int remove_loader_variables(void) { static int remove_loader_variables(void) {
const char *variable;
int r = 0; int r = 0;
/* Remove all persistent loader variables we define */ /* Remove all persistent loader variables we define */
FOREACH_STRING(variable, FOREACH_STRING(var,
EFI_LOADER_VARIABLE(LoaderConfigTimeout), EFI_LOADER_VARIABLE(LoaderConfigTimeout),
EFI_LOADER_VARIABLE(LoaderConfigTimeoutOneShot), EFI_LOADER_VARIABLE(LoaderConfigTimeoutOneShot),
EFI_LOADER_VARIABLE(LoaderEntryDefault), EFI_LOADER_VARIABLE(LoaderEntryDefault),
@ -1269,15 +1268,15 @@ static int remove_loader_variables(void) {
int q; int q;
q = efi_set_variable(variable, NULL, 0); q = efi_set_variable(var, NULL, 0);
if (q == -ENOENT) if (q == -ENOENT)
continue; continue;
if (q < 0) { if (q < 0) {
log_warning_errno(q, "Failed to remove EFI variable %s: %m", variable); log_warning_errno(q, "Failed to remove EFI variable %s: %m", var);
if (r >= 0) if (r >= 0)
r = q; r = q;
} else } else
log_info("Removed EFI variable %s.", variable); log_info("Removed EFI variable %s.", var);
} }
return r; return r;

View File

@ -510,7 +510,6 @@ static int refresh_one(
} }
static int refresh(const char *root, Hashmap *a, Hashmap *b, unsigned iteration) { static int refresh(const char *root, Hashmap *a, Hashmap *b, unsigned iteration) {
const char *c;
int r; int r;
FOREACH_STRING(c, SYSTEMD_CGROUP_CONTROLLER, "cpu", "cpuacct", "memory", "io", "blkio", "pids") { FOREACH_STRING(c, SYSTEMD_CGROUP_CONTROLLER, "cpu", "cpuacct", "memory", "io", "blkio", "pids") {

View File

@ -24,7 +24,6 @@ int mac_apparmor_setup(void) {
#if HAVE_APPARMOR #if HAVE_APPARMOR
_cleanup_(aa_policy_cache_unrefp) aa_policy_cache *policy_cache = NULL; _cleanup_(aa_policy_cache_unrefp) aa_policy_cache *policy_cache = NULL;
_cleanup_(aa_features_unrefp) aa_features *features = NULL; _cleanup_(aa_features_unrefp) aa_features *features = NULL;
const char *current_file;
_cleanup_free_ char *current_profile = NULL, *cache_dir_path = NULL; _cleanup_free_ char *current_profile = NULL, *cache_dir_path = NULL;
int r; int r;

View File

@ -786,7 +786,6 @@ void cgroup_oomd_xattr_apply(Unit *u, const char *cgroup_path) {
} }
static void cgroup_xattr_apply(Unit *u) { static void cgroup_xattr_apply(Unit *u) {
const char *xn;
bool b; bool b;
assert(u); assert(u);

View File

@ -20,24 +20,23 @@
* is suitably validated. */ * is suitably validated. */
static void lock_down_efi_variables(void) { static void lock_down_efi_variables(void) {
const char *p;
int r; int r;
/* Paranoia: let's restrict access modes of these a bit, so that unprivileged users can't use them to /* Paranoia: let's restrict access modes of these a bit, so that unprivileged users can't use them to
* identify the system or gain too much insight into what we might have credited to the entropy * identify the system or gain too much insight into what we might have credited to the entropy
* pool. */ * pool. */
FOREACH_STRING(p, FOREACH_STRING(path,
EFIVAR_PATH(EFI_LOADER_VARIABLE(LoaderRandomSeed)), EFIVAR_PATH(EFI_LOADER_VARIABLE(LoaderRandomSeed)),
EFIVAR_PATH(EFI_LOADER_VARIABLE(LoaderSystemToken))) { EFIVAR_PATH(EFI_LOADER_VARIABLE(LoaderSystemToken))) {
r = chattr_path(p, 0, FS_IMMUTABLE_FL, NULL); r = chattr_path(path, 0, FS_IMMUTABLE_FL, NULL);
if (r == -ENOENT) if (r == -ENOENT)
continue; continue;
if (r < 0) if (r < 0)
log_warning_errno(r, "Failed to drop FS_IMMUTABLE_FL from %s, ignoring: %m", p); log_warning_errno(r, "Failed to drop FS_IMMUTABLE_FL from %s, ignoring: %m", path);
if (chmod(p, 0600) < 0) if (chmod(path, 0600) < 0)
log_warning_errno(errno, "Failed to reduce access mode of %s, ignoring: %m", p); log_warning_errno(errno, "Failed to reduce access mode of %s, ignoring: %m", path);
} }
} }

View File

@ -3043,7 +3043,6 @@ static int setup_credentials(
uid_t uid) { uid_t uid) {
_cleanup_free_ char *p = NULL, *q = NULL; _cleanup_free_ char *p = NULL, *q = NULL;
const char *i;
int r; int r;
assert(context); assert(context);

View File

@ -99,8 +99,6 @@ static int timer_add_default_dependencies(Timer *t) {
return r; return r;
LIST_FOREACH(value, v, t->values) { LIST_FOREACH(value, v, t->values) {
const char *target;
if (v->base != TIMER_CALENDAR) if (v->base != TIMER_CALENDAR)
continue; continue;

View File

@ -4133,7 +4133,6 @@ int unit_patch_contexts(Unit *u) {
if ((ec->root_image || !LIST_IS_EMPTY(ec->mount_images)) && if ((ec->root_image || !LIST_IS_EMPTY(ec->mount_images)) &&
(cc->device_policy != CGROUP_DEVICE_POLICY_AUTO || cc->device_allow)) { (cc->device_policy != CGROUP_DEVICE_POLICY_AUTO || cc->device_allow)) {
const char *p;
/* When RootImage= or MountImages= is specified, the following devices are touched. */ /* When RootImage= or MountImages= is specified, the following devices are touched. */
FOREACH_STRING(p, "/dev/loop-control", "/dev/mapper/control") { FOREACH_STRING(p, "/dev/loop-control", "/dev/mapper/control") {

View File

@ -215,9 +215,7 @@ static int run(const char *dest, const char *dest_early, const char *dest_late)
return r; return r;
} }
/* Automatically add in a serial getty on the first /* Automatically add in a serial getty on the first virtualizer console */
* virtualizer console */
const char *j;
FOREACH_STRING(j, FOREACH_STRING(j,
"hvc0", "hvc0",
"xvc0", "xvc0",

View File

@ -2949,8 +2949,6 @@ static int parse_argv(int argc, char *argv[]) {
case ARG_DISK_SIZE: case ARG_DISK_SIZE:
if (isempty(optarg)) { if (isempty(optarg)) {
const char *prop;
FOREACH_STRING(prop, "diskSize", "diskSizeRelative", "rebalanceWeight") { FOREACH_STRING(prop, "diskSize", "diskSizeRelative", "rebalanceWeight") {
r = drop_from_identity(prop); r = drop_from_identity(prop);
if (r < 0) if (r < 0)
@ -3452,9 +3450,7 @@ static int parse_argv(int argc, char *argv[]) {
break; break;
} }
case ARG_PKCS11_TOKEN_URI: { case ARG_PKCS11_TOKEN_URI:
const char *p;
if (streq(optarg, "list")) if (streq(optarg, "list"))
return pkcs11_list_tokens(); return pkcs11_list_tokens();
@ -3488,11 +3484,8 @@ static int parse_argv(int argc, char *argv[]) {
strv_uniq(arg_pkcs11_token_uri); strv_uniq(arg_pkcs11_token_uri);
break; break;
}
case ARG_FIDO2_DEVICE: {
const char *p;
case ARG_FIDO2_DEVICE:
if (streq(optarg, "list")) if (streq(optarg, "list"))
return fido2_list_devices(); return fido2_list_devices();
@ -3522,7 +3515,6 @@ static int parse_argv(int argc, char *argv[]) {
strv_uniq(arg_fido2_device); strv_uniq(arg_fido2_device);
break; break;
}
case ARG_FIDO2_WITH_PIN: { case ARG_FIDO2_WITH_PIN: {
bool lock_with_pin; bool lock_with_pin;
@ -3557,9 +3549,7 @@ static int parse_argv(int argc, char *argv[]) {
break; break;
} }
case ARG_RECOVERY_KEY: { case ARG_RECOVERY_KEY:
const char *p;
r = parse_boolean(optarg); r = parse_boolean(optarg);
if (r < 0) if (r < 0)
return log_error_errno(r, "Failed to parse --recovery-key= argument: %s", optarg); return log_error_errno(r, "Failed to parse --recovery-key= argument: %s", optarg);
@ -3573,7 +3563,6 @@ static int parse_argv(int argc, char *argv[]) {
} }
break; break;
}
case ARG_AUTO_RESIZE_MODE: case ARG_AUTO_RESIZE_MODE:
if (isempty(optarg)) { if (isempty(optarg)) {

View File

@ -482,7 +482,6 @@ static int manager_enumerate_records(Manager *m) {
static int search_quota(uid_t uid, const char *exclude_quota_path) { static int search_quota(uid_t uid, const char *exclude_quota_path) {
struct stat exclude_st = {}; struct stat exclude_st = {};
dev_t previous_devno = 0; dev_t previous_devno = 0;
const char *where;
int r; int r;
/* Checks whether the specified UID owns any files on the files system, but ignore any file system /* Checks whether the specified UID owns any files on the files system, but ignore any file system

View File

@ -332,7 +332,6 @@ _public_ int sd_device_new_from_subsystem_sysname(
const char *subsystem, const char *subsystem,
const char *sysname) { const char *sysname) {
const char *s;
char *name; char *name;
int r; int r;
@ -341,7 +340,6 @@ _public_ int sd_device_new_from_subsystem_sysname(
assert_return(path_is_normalized(sysname), -EINVAL); assert_return(path_is_normalized(sysname), -EINVAL);
if (streq(subsystem, "subsystem")) { if (streq(subsystem, "subsystem")) {
FOREACH_STRING(s, "/sys/subsystem/", "/sys/bus/", "/sys/class/") { FOREACH_STRING(s, "/sys/subsystem/", "/sys/bus/", "/sys/class/") {
r = device_strjoin_new(s, sysname, NULL, NULL, ret); r = device_strjoin_new(s, sysname, NULL, NULL, ret);
if (r < 0) if (r < 0)
@ -351,7 +349,6 @@ _public_ int sd_device_new_from_subsystem_sysname(
} }
} else if (streq(subsystem, "module")) { } else if (streq(subsystem, "module")) {
r = device_strjoin_new("/sys/module/", sysname, NULL, NULL, ret); r = device_strjoin_new("/sys/module/", sysname, NULL, NULL, ret);
if (r < 0) if (r < 0)
return r; return r;
@ -363,9 +360,8 @@ _public_ int sd_device_new_from_subsystem_sysname(
sep = strchr(sysname, ':'); sep = strchr(sysname, ':');
if (sep && sep[1] != '\0') { /* Require ":" and something non-empty after that. */ if (sep && sep[1] != '\0') { /* Require ":" and something non-empty after that. */
const char *subsys;
subsys = memdupa_suffix0(sysname, sep - sysname); const char *subsys = memdupa_suffix0(sysname, sep - sysname);
sep++; sep++;
FOREACH_STRING(s, "/sys/subsystem/", "/sys/bus/") { FOREACH_STRING(s, "/sys/subsystem/", "/sys/bus/") {

View File

@ -474,7 +474,7 @@ static int method_set_locale(sd_bus_message *m, void *userdata, sd_bus_error *er
static int method_set_vc_keyboard(sd_bus_message *m, void *userdata, sd_bus_error *error) { static int method_set_vc_keyboard(sd_bus_message *m, void *userdata, sd_bus_error *error) {
Context *c = userdata; Context *c = userdata;
const char *name, *keymap, *keymap_toggle; const char *keymap, *keymap_toggle;
int convert, interactive, r; int convert, interactive, r;
assert(m); assert(m);

View File

@ -627,7 +627,6 @@ int user_check_linger_file(User *u) {
} }
static bool user_unit_active(User *u) { static bool user_unit_active(User *u) {
const char *i;
int r; int r;
assert(u->service); assert(u->service);

View File

@ -22,7 +22,6 @@
static int chown_cgroup_path(const char *path, uid_t uid_shift) { static int chown_cgroup_path(const char *path, uid_t uid_shift) {
_cleanup_close_ int fd = -1; _cleanup_close_ int fd = -1;
const char *fn;
fd = open(path, O_RDONLY|O_CLOEXEC|O_DIRECTORY); fd = open(path, O_RDONLY|O_CLOEXEC|O_DIRECTORY);
if (fd < 0) if (fd < 0)

View File

@ -404,7 +404,7 @@ int tmpfs_patch_options(
} }
int mount_sysfs(const char *dest, MountSettingsMask mount_settings) { int mount_sysfs(const char *dest, MountSettingsMask mount_settings) {
const char *full, *top, *x; const char *full, *top;
int r; int r;
unsigned long extra_flags = 0; unsigned long extra_flags = 0;
@ -464,7 +464,7 @@ int mount_sysfs(const char *dest, MountSettingsMask mount_settings) {
/* Create mountpoint for cgroups. Otherwise we are not allowed since we /* Create mountpoint for cgroups. Otherwise we are not allowed since we
* remount /sys read-only. * remount /sys read-only.
*/ */
x = prefix_roota(top, "/fs/cgroup"); const char *x = prefix_roota(top, "/fs/cgroup");
(void) mkdir_p(x, 0755); (void) mkdir_p(x, 0755);
return mount_nofollow_verbose(LOG_ERR, NULL, top, NULL, return mount_nofollow_verbose(LOG_ERR, NULL, top, NULL,

View File

@ -2564,7 +2564,7 @@ static int setup_hostname(void) {
static int setup_journal(const char *directory) { static int setup_journal(const char *directory) {
_cleanup_free_ char *d = NULL; _cleanup_free_ char *d = NULL;
const char *dirname, *p, *q; const char *p, *q;
sd_id128_t this_id; sd_id128_t this_id;
bool try; bool try;
int r; int r;
@ -3512,7 +3512,6 @@ static int inner_child(
(void) fdset_close_others(fds); (void) fdset_close_others(fds);
if (arg_start_mode == START_BOOT) { if (arg_start_mode == START_BOOT) {
const char *init;
char **a; char **a;
size_t m; size_t m;
@ -4603,7 +4602,7 @@ static int load_settings(void) {
_cleanup_(settings_freep) Settings *settings = NULL; _cleanup_(settings_freep) Settings *settings = NULL;
_cleanup_fclose_ FILE *f = NULL; _cleanup_fclose_ FILE *f = NULL;
_cleanup_free_ char *p = NULL; _cleanup_free_ char *p = NULL;
const char *fn, *i; const char *fn;
int r; int r;
if (arg_oci_bundle) if (arg_oci_bundle)

View File

@ -4533,9 +4533,8 @@ static int acquire_root_devno(
} }
static int find_root(char **ret, int *ret_fd) { static int find_root(char **ret, int *ret_fd) {
const char *p;
int r;
_cleanup_free_ char *device = NULL; _cleanup_free_ char *device = NULL;
int r;
assert(ret); assert(ret);
assert(ret_fd); assert(ret_fd);

View File

@ -1599,7 +1599,6 @@ int portable_detach(
SET_FOREACH(item, unit_files) { SET_FOREACH(item, unit_files) {
_cleanup_free_ char *md = NULL; _cleanup_free_ char *md = NULL;
const char *suffix;
if (unlinkat(dirfd(d), item, 0) < 0) { if (unlinkat(dirfd(d), item, 0) < 0) {
log_debug_errno(errno, "Can't remove unit file %s/%s: %m", where, item); log_debug_errno(errno, "Can't remove unit file %s/%s: %m", where, item);

View File

@ -50,8 +50,6 @@ int manager_check_resolv_conf(const Manager *m) {
} }
static bool file_is_our_own(const struct stat *st) { static bool file_is_our_own(const struct stat *st) {
const char *path;
assert(st); assert(st);
FOREACH_STRING(path, FOREACH_STRING(path,

View File

@ -41,7 +41,6 @@ TEST(parse_etc_hosts) {
int fd; int fd;
_cleanup_fclose_ FILE *f; _cleanup_fclose_ FILE *f;
const char *s;
fd = mkostemp_safe(t); fd = mkostemp_safe(t);
assert_se(fd >= 0); assert_se(fd >= 0);

View File

@ -1702,8 +1702,6 @@ static int start_transient_trigger(
} }
static bool shall_make_executable_absolute(void) { static bool shall_make_executable_absolute(void) {
const char *f;
if (strv_isempty(arg_cmdline)) if (strv_isempty(arg_cmdline))
return false; return false;
if (arg_transport != BUS_TRANSPORT_LOCAL) if (arg_transport != BUS_TRANSPORT_LOCAL)

View File

@ -21,7 +21,6 @@ static int chown_one(
gid_t gid, gid_t gid,
mode_t mask) { mode_t mask) {
const char *n;
int r; int r;
assert(fd >= 0); assert(fd >= 0);

View File

@ -85,7 +85,7 @@ DEFINE_HASH_OPS_WITH_VALUE_DESTRUCTOR(image_hash_ops, char, string_hash_func, st
static char **image_settings_path(Image *image) { static char **image_settings_path(Image *image) {
_cleanup_strv_free_ char **l = NULL; _cleanup_strv_free_ char **l = NULL;
const char *fn, *s; const char *fn;
unsigned i = 0; unsigned i = 0;
assert(image); assert(image);

View File

@ -3041,7 +3041,6 @@ int dissected_image_acquire_metadata(DissectedImage *m, DissectImageFlags extra_
case META_HAS_INIT_SYSTEM: { case META_HAS_INIT_SYSTEM: {
bool found = false; bool found = false;
const char *init;
FOREACH_STRING(init, FOREACH_STRING(init,
"/usr/lib/systemd/systemd", /* systemd on /usr merged system */ "/usr/lib/systemd/systemd", /* systemd on /usr merged system */

View File

@ -435,7 +435,8 @@ int find_esp_and_warn(
goto found; goto found;
} }
FOREACH_STRING(path, "/efi", "/boot", "/boot/efi") { FOREACH_STRING(_path, "/efi", "/boot", "/boot/efi") {
path = _path;
r = verify_esp(path, /* searching= */ true, unprivileged_mode, ret_part, ret_pstart, ret_psize, ret_uuid, ret_devid); r = verify_esp(path, /* searching= */ true, unprivileged_mode, ret_part, ret_pstart, ret_psize, ret_uuid, ret_devid);
if (r >= 0) if (r >= 0)

View File

@ -197,7 +197,7 @@ finish:
int machine_id_commit(const char *root) { int machine_id_commit(const char *root) {
_cleanup_close_ int fd = -1, initial_mntns_fd = -1; _cleanup_close_ int fd = -1, initial_mntns_fd = -1;
const char *etc_machine_id, *sync_path; const char *etc_machine_id;
sd_id128_t id; sd_id128_t id;
int r; int r;

View File

@ -126,9 +126,6 @@ bool mount_point_is_api(const char *path) {
} }
bool mount_point_ignore(const char *path) { bool mount_point_ignore(const char *path) {
const char *i;
/* These are API file systems that might be mounted by other software, we just list them here so that /* These are API file systems that might be mounted by other software, we just list them here so that
* we know that we should ignore them. */ * we know that we should ignore them. */
FOREACH_STRING(i, FOREACH_STRING(i,
@ -515,7 +512,6 @@ int mount_setup(bool loaded_policy, bool leave_propagation) {
* use the same label for all their files. */ * use the same label for all their files. */
if (loaded_policy) { if (loaded_policy) {
usec_t before_relabel, after_relabel; usec_t before_relabel, after_relabel;
const char *i;
int n_extra; int n_extra;
before_relabel = now(CLOCK_MONOTONIC); before_relabel = now(CLOCK_MONOTONIC);

View File

@ -54,14 +54,15 @@ int net_get_type_string(sd_device *device, uint16_t iftype, char **ret) {
} }
const char *net_get_persistent_name(sd_device *device) { const char *net_get_persistent_name(sd_device *device) {
const char *name, *field;
assert(device); assert(device);
/* fetch some persistent data unique (on this machine) to this device */ /* fetch some persistent data unique (on this machine) to this device */
FOREACH_STRING(field, "ID_NET_NAME_ONBOARD", "ID_NET_NAME_SLOT", "ID_NET_NAME_PATH", "ID_NET_NAME_MAC") FOREACH_STRING(field, "ID_NET_NAME_ONBOARD", "ID_NET_NAME_SLOT", "ID_NET_NAME_PATH", "ID_NET_NAME_MAC") {
const char *name;
if (sd_device_get_property_value(device, field, &name) >= 0) if (sd_device_get_property_value(device, field, &name) >= 0)
return name; return name;
}
return NULL; return NULL;
} }

View File

@ -144,7 +144,7 @@ void pager_open(PagerFlags flags) {
if (r < 0) if (r < 0)
return; return;
if (r == 0) { if (r == 0) {
const char *less_charset, *exe; const char *less_charset;
/* In the child start the pager */ /* In the child start the pager */

View File

@ -106,8 +106,6 @@ int read_resource_pressure(const char *path, PressureType type, ResourcePressure
} }
int is_pressure_supported(void) { int is_pressure_supported(void) {
const char *p;
/* The pressure files, both under /proc and in cgroups, will exist /* The pressure files, both under /proc and in cgroups, will exist
* even if the kernel has PSI support disabled; we have to read * even if the kernel has PSI support disabled; we have to read
* the file to make sure it doesn't return -EOPNOTSUPP */ * the file to make sure it doesn't return -EOPNOTSUPP */

View File

@ -33,7 +33,6 @@ int switch_root(const char *new_root,
_cleanup_free_ char *resolved_old_root_after = NULL; _cleanup_free_ char *resolved_old_root_after = NULL;
_cleanup_close_ int old_root_fd = -1; _cleanup_close_ int old_root_fd = -1;
bool old_root_remove; bool old_root_remove;
const char *i;
int r; int r;
assert(new_root); assert(new_root);
@ -64,12 +63,12 @@ int switch_root(const char *new_root,
if (mount(NULL, "/", NULL, MS_REC|MS_PRIVATE, NULL) < 0) if (mount(NULL, "/", NULL, MS_REC|MS_PRIVATE, NULL) < 0)
return log_error_errno(errno, "Failed to set \"/\" mount propagation to private: %m"); return log_error_errno(errno, "Failed to set \"/\" mount propagation to private: %m");
FOREACH_STRING(i, "/sys", "/dev", "/run", "/proc") { FOREACH_STRING(path, "/sys", "/dev", "/run", "/proc") {
_cleanup_free_ char *chased = NULL; _cleanup_free_ char *chased = NULL;
r = chase_symlinks(i, new_root, CHASE_PREFIX_ROOT|CHASE_NONEXISTENT, &chased, NULL); r = chase_symlinks(path, new_root, CHASE_PREFIX_ROOT|CHASE_NONEXISTENT, &chased, NULL);
if (r < 0) if (r < 0)
return log_error_errno(r, "Failed to resolve %s/%s: %m", new_root, i); return log_error_errno(r, "Failed to resolve %s/%s: %m", new_root, path);
if (r > 0) { if (r > 0) {
/* Already exists. Let's see if it is a mount point already. */ /* Already exists. Let's see if it is a mount point already. */
r = path_is_mount_point(chased, NULL, 0); r = path_is_mount_point(chased, NULL, 0);
@ -81,8 +80,8 @@ int switch_root(const char *new_root,
/* Doesn't exist yet? */ /* Doesn't exist yet? */
(void) mkdir_p_label(chased, 0755); (void) mkdir_p_label(chased, 0755);
if (mount(i, chased, NULL, mount_flags, NULL) < 0) if (mount(path, chased, NULL, mount_flags, NULL) < 0)
return log_error_errno(errno, "Failed to mount %s to %s: %m", i, chased); return log_error_errno(errno, "Failed to mount %s to %s: %m", path, chased);
} }
/* Do not fail if base_filesystem_create() fails. Not all switch roots are like base_filesystem_create() wants /* Do not fail if base_filesystem_create() fails. Not all switch roots are like base_filesystem_create() wants

View File

@ -306,16 +306,15 @@ const char *ci_environment(void) {
* just the general CI environment type, but also whether we're sanitizing or not, etc. The caller is * just the general CI environment type, but also whether we're sanitizing or not, etc. The caller is
* expected to use strstr on the returned value. */ * expected to use strstr on the returned value. */
static const char *ans = POINTER_MAX; static const char *ans = POINTER_MAX;
const char *p;
int r; int r;
if (ans != POINTER_MAX) if (ans != POINTER_MAX)
return ans; return ans;
/* We allow specifying the environment with $CITYPE. Nobody uses this so far, but we are ready. */ /* We allow specifying the environment with $CITYPE. Nobody uses this so far, but we are ready. */
p = getenv("CITYPE"); const char *citype = getenv("CITYPE");
if (!isempty(p)) if (!isempty(citype))
return (ans = p); return (ans = citype);
if (getenv_bool("TRAVIS") > 0) if (getenv_bool("TRAVIS") > 0)
return (ans = "travis"); return (ans = "travis");
@ -326,12 +325,12 @@ const char *ci_environment(void) {
if (getenv("AUTOPKGTEST_ARTIFACTS") || getenv("AUTOPKGTEST_TMP")) if (getenv("AUTOPKGTEST_ARTIFACTS") || getenv("AUTOPKGTEST_TMP"))
return (ans = "autopkgtest"); return (ans = "autopkgtest");
FOREACH_STRING(p, "CI", "CONTINOUS_INTEGRATION") { FOREACH_STRING(var, "CI", "CONTINOUS_INTEGRATION") {
/* Those vars are booleans according to Semaphore and Travis docs: /* Those vars are booleans according to Semaphore and Travis docs:
* https://docs.travis-ci.com/user/environment-variables/#default-environment-variables * https://docs.travis-ci.com/user/environment-variables/#default-environment-variables
* https://docs.semaphoreci.com/ci-cd-environment/environment-variables/#ci * https://docs.semaphoreci.com/ci-cd-environment/environment-variables/#ci
*/ */
r = getenv_bool(p); r = getenv_bool(var);
if (r > 0) if (r > 0)
return (ans = "unknown"); /* Some other unknown thing */ return (ans = "unknown"); /* Some other unknown thing */
if (r == 0) if (r == 0)

View File

@ -318,7 +318,7 @@ static int run_editor(char **paths) {
if (r == 0) { if (r == 0) {
char **editor_args = NULL; char **editor_args = NULL;
size_t n_editor_args = 0, i = 1, argc; size_t n_editor_args = 0, i = 1, argc;
const char **args, *editor, *p; const char **args, *editor;
argc = strv_length(paths)/2 + 1; argc = strv_length(paths)/2 + 1;
@ -356,9 +356,9 @@ static int run_editor(char **paths) {
if (n_editor_args > 0) if (n_editor_args > 0)
execvp(args[0], (char* const*) args); execvp(args[0], (char* const*) args);
FOREACH_STRING(p, "editor", "nano", "vim", "vi") { FOREACH_STRING(name, "editor", "nano", "vim", "vi") {
args[0] = p; args[0] = name;
execvp(p, (char* const*) args); execvp(name, (char* const*) args);
/* We do not fail if the editor doesn't exist because we want to try each one of them /* We do not fail if the editor doesn't exist because we want to try each one of them
* before failing. */ * before failing. */
if (errno != ENOENT) { if (errno != ENOENT) {

View File

@ -18,9 +18,8 @@
int talk_initctl(char rl) { int talk_initctl(char rl) {
#if HAVE_SYSV_COMPAT #if HAVE_SYSV_COMPAT
struct init_request request;
_cleanup_close_ int fd = -1; _cleanup_close_ int fd = -1;
const char *p; const char *path;
int r; int r;
/* Try to switch to the specified SysV runlevel. Returns == 0 if the operation does not apply on this /* Try to switch to the specified SysV runlevel. Returns == 0 if the operation does not apply on this
@ -29,19 +28,19 @@ int talk_initctl(char rl) {
if (rl == 0) if (rl == 0)
return 0; return 0;
FOREACH_STRING(p, "/run/initctl", "/dev/initctl") { FOREACH_STRING(_path, "/run/initctl", "/dev/initctl") {
fd = open(p, O_WRONLY|O_NONBLOCK|O_CLOEXEC|O_NOCTTY); path = _path;
if (fd >= 0 || errno != ENOENT)
fd = open(path, O_WRONLY|O_NONBLOCK|O_CLOEXEC|O_NOCTTY);
if (fd < 0 && errno != ENOENT)
return log_error_errno(errno, "Failed to open %s: %m", path);
if (fd >= 0)
break; break;
} }
if (fd < 0) { if (fd < 0)
if (errno == ENOENT) return 0;
return 0;
return log_error_errno(errno, "Failed to open initctl fifo: %m"); struct init_request request = {
}
request = (struct init_request) {
.magic = INIT_MAGIC, .magic = INIT_MAGIC,
.sleeptime = 0, .sleeptime = 0,
.cmd = INIT_CMD_RUNLVL, .cmd = INIT_CMD_RUNLVL,
@ -50,7 +49,7 @@ int talk_initctl(char rl) {
r = loop_write(fd, &request, sizeof(request), false); r = loop_write(fd, &request, sizeof(request), false);
if (r < 0) if (r < 0)
return log_error_errno(r, "Failed to write to %s: %m", p); return log_error_errno(r, "Failed to write to %s: %m", path);
return 1; return 1;
#else #else

View File

@ -30,7 +30,6 @@ static void test_policy_closed(const char *cgroup_path, BPFProgram **installed_p
r = bpf_devices_apply_policy(&prog, CGROUP_DEVICE_POLICY_CLOSED, true, cgroup_path, installed_prog); r = bpf_devices_apply_policy(&prog, CGROUP_DEVICE_POLICY_CLOSED, true, cgroup_path, installed_prog);
assert_se(r >= 0); assert_se(r >= 0);
const char *s;
FOREACH_STRING(s, "/dev/null", FOREACH_STRING(s, "/dev/null",
"/dev/zero", "/dev/zero",
"/dev/full", "/dev/full",

View File

@ -64,18 +64,14 @@ static void test_ellipsize_mem_one(const char *s, size_t old_length, size_t new_
} }
TEST(ellipsize_mem) { TEST(ellipsize_mem) {
const char *s;
ssize_t l, k;
FOREACH_STRING(s, FOREACH_STRING(s,
"_XXXXXXXXXXX_", /* ASCII */ "_XXXXXXXXXXX_", /* ASCII */
"_aąęółśćńżźć_", /* two-byte utf-8 */ "_aąęółśćńżźć_", /* two-byte utf-8 */
"გამარჯობა", /* multi-byte utf-8 */ "გამარჯობა", /* multi-byte utf-8 */
"你好世界", /* wide characters */ "你好世界", /* wide characters */
"你გą世óoó界") /* a mix */ "你გą世óoó界") /* a mix */
for (ssize_t l = strlen(s); l >= 0; l--)
for (l = strlen(s); l >= 0; l--) for (ssize_t k = strlen(s) + 1; k >= 0; k--)
for (k = strlen(s) + 1; k >= 0; k--)
test_ellipsize_mem_one(s, l, k); test_ellipsize_mem_one(s, l, k);
} }

View File

@ -166,8 +166,6 @@ TEST(load_env_file_6) {
} }
TEST(write_and_load_env_file) { TEST(write_and_load_env_file) {
const char *v;
/* Make sure that our writer, parser and the shell agree on what our env var files mean */ /* Make sure that our writer, parser and the shell agree on what our env var files mean */
FOREACH_STRING(v, FOREACH_STRING(v,

View File

@ -190,19 +190,15 @@ static bool check_user_has_group_with_same_name(const char *name) {
} }
static bool is_inaccessible_available(void) { static bool is_inaccessible_available(void) {
const char *p;
FOREACH_STRING(p, FOREACH_STRING(p,
"/run/systemd/inaccessible/reg", "/run/systemd/inaccessible/reg",
"/run/systemd/inaccessible/dir", "/run/systemd/inaccessible/dir",
"/run/systemd/inaccessible/chr", "/run/systemd/inaccessible/chr",
"/run/systemd/inaccessible/blk", "/run/systemd/inaccessible/blk",
"/run/systemd/inaccessible/fifo", "/run/systemd/inaccessible/fifo",
"/run/systemd/inaccessible/sock" "/run/systemd/inaccessible/sock")
) {
if (access(p, F_OK) < 0) if (access(p, F_OK) < 0)
return false; return false;
}
return true; return true;
} }

View File

@ -998,7 +998,6 @@ TEST(read_full_file_offset_size) {
} }
static void test_read_virtual_file_one(size_t max_size) { static void test_read_virtual_file_one(size_t max_size) {
const char *filename;
int r; int r;
log_info("/* %s (max_size=%zu) */", __func__, max_size); log_info("/* %s (max_size=%zu) */", __func__, max_size);

View File

@ -11,16 +11,13 @@
#include "util.h" #include "util.h"
TEST(gpt_types_against_architectures) { TEST(gpt_types_against_architectures) {
const char *prefix;
int r; int r;
/* Dumps a table indicating for which architectures we know we have matching GPT partition /* Dumps a table indicating for which architectures we know we have matching GPT partition
* types. Also validates whether we can properly categorize the entries. */ * types. Also validates whether we can properly categorize the entries. */
FOREACH_STRING(prefix, "root-", "usr-") FOREACH_STRING(prefix, "root-", "usr-")
for (int a = 0; a < _ARCHITECTURE_MAX; a++) { for (int a = 0; a < _ARCHITECTURE_MAX; a++)
const char *suffix;
FOREACH_STRING(suffix, "", "-verity", "-verity-sig") { FOREACH_STRING(suffix, "", "-verity", "-verity-sig") {
_cleanup_free_ char *joined = NULL; _cleanup_free_ char *joined = NULL;
sd_id128_t id; sd_id128_t id;
@ -48,7 +45,6 @@ TEST(gpt_types_against_architectures) {
assert_se(gpt_partition_type_uuid_to_arch(id) == a); assert_se(gpt_partition_type_uuid_to_arch(id) == a);
} }
}
} }
DEFINE_TEST_MAIN(LOG_INFO); DEFINE_TEST_MAIN(LOG_INFO);

View File

@ -39,7 +39,6 @@ static int test_hash_password(void) {
/* As a warm-up exercise, check if we can hash passwords. */ /* As a warm-up exercise, check if we can hash passwords. */
bool have_sane_hash = false; bool have_sane_hash = false;
const char *hash;
FOREACH_STRING(hash, FOREACH_STRING(hash,
"ew3bU1.hoKk4o", "ew3bU1.hoKk4o",
@ -68,7 +67,6 @@ static void test_hash_password_full(void) {
log_info("/* %s */", __func__); log_info("/* %s */", __func__);
_cleanup_free_ void *cd_data = NULL; _cleanup_free_ void *cd_data = NULL;
const char *i;
int cd_size = 0; int cd_size = 0;
log_info("sizeof(struct crypt_data): %zu bytes", sizeof(struct crypt_data)); log_info("sizeof(struct crypt_data): %zu bytes", sizeof(struct crypt_data));

View File

@ -114,7 +114,6 @@ int main(int argc, char *argv[]) {
_cleanup_(dissected_image_unrefp) DissectedImage *dissected = NULL; _cleanup_(dissected_image_unrefp) DissectedImage *dissected = NULL;
_cleanup_(umount_and_rmdir_and_freep) char *mounted = NULL; _cleanup_(umount_and_rmdir_and_freep) char *mounted = NULL;
pthread_t threads[N_THREADS]; pthread_t threads[N_THREADS];
const char *fs;
sd_id128_t id; sd_id128_t id;
int r; int r;

View File

@ -128,7 +128,6 @@ TEST(mount_flags_to_string) {
TEST(bind_remount_recursive) { TEST(bind_remount_recursive) {
_cleanup_(rm_rf_physical_and_freep) char *tmp = NULL; _cleanup_(rm_rf_physical_and_freep) char *tmp = NULL;
_cleanup_free_ char *subdir = NULL; _cleanup_free_ char *subdir = NULL;
const char *p;
if (geteuid() != 0 || have_effective_cap(CAP_SYS_ADMIN) <= 0) { if (geteuid() != 0 || have_effective_cap(CAP_SYS_ADMIN) <= 0) {
(void) log_tests_skipped("not running privileged"); (void) log_tests_skipped("not running privileged");

View File

@ -67,7 +67,6 @@ TEST(path_is_fs_type) {
} }
TEST(path_is_temporary_fs) { TEST(path_is_temporary_fs) {
const char *s;
int r; int r;
FOREACH_STRING(s, "/", "/run", "/sys", "/sys/", "/proc", "/i-dont-exist", "/var", "/var/lib") { FOREACH_STRING(s, "/", "/run", "/sys", "/sys/", "/proc", "/i-dont-exist", "/var", "/var/lib") {
@ -85,7 +84,6 @@ TEST(path_is_temporary_fs) {
} }
TEST(path_is_read_only_fs) { TEST(path_is_read_only_fs) {
const char *s;
int r; int r;
FOREACH_STRING(s, "/", "/run", "/sys", "/sys/", "/proc", "/i-dont-exist", "/var", "/var/lib") { FOREACH_STRING(s, "/", "/run", "/sys", "/sys/", "/proc", "/i-dont-exist", "/var", "/var/lib") {

View File

@ -924,12 +924,10 @@ TEST(foreach_string) {
"waldo", "waldo",
NULL NULL
}; };
const char *x;
unsigned i = 0;
unsigned i = 0;
FOREACH_STRING(x, "foo", "bar", "waldo") FOREACH_STRING(x, "foo", "bar", "waldo")
assert_se(streq_ptr(t[i++], x)); assert_se(streq_ptr(t[i++], x));
assert_se(i == 3); assert_se(i == 3);
FOREACH_STRING(x, "zzz") FOREACH_STRING(x, "zzz")

View File

@ -144,7 +144,6 @@ TEST(utf8_escape_non_printable) {
} }
TEST(utf8_escape_non_printable_full) { TEST(utf8_escape_non_printable_full) {
const char *s;
FOREACH_STRING(s, FOREACH_STRING(s,
"goo goo goo", /* ASCII */ "goo goo goo", /* ASCII */
"\001 \019\20\a", /* control characters */ "\001 \019\20\a", /* control characters */
@ -210,8 +209,6 @@ TEST(utf8_console_width) {
} }
TEST(utf8_to_utf16) { TEST(utf8_to_utf16) {
const char *p;
FOREACH_STRING(p, FOREACH_STRING(p,
"abc", "abc",
"zażółcić gęślą jaźń", "zażółcić gęślą jaźń",

View File

@ -39,7 +39,6 @@ static int populate_uid_cache(const char *root, Hashmap **ret) {
/* The directory list is hardcoded here: /etc is the standard, and rpm-ostree uses /usr/lib. This /* The directory list is hardcoded here: /etc is the standard, and rpm-ostree uses /usr/lib. This
* could be made configurable, but I don't see the point right now. */ * could be made configurable, but I don't see the point right now. */
const char *fname;
FOREACH_STRING(fname, "/etc/passwd", "/usr/lib/passwd") { FOREACH_STRING(fname, "/etc/passwd", "/usr/lib/passwd") {
_cleanup_fclose_ FILE *f = NULL; _cleanup_fclose_ FILE *f = NULL;
@ -78,7 +77,6 @@ static int populate_gid_cache(const char *root, Hashmap **ret) {
if (!cache) if (!cache)
return -ENOMEM; return -ENOMEM;
const char *fname;
FOREACH_STRING(fname, "/etc/group", "/usr/lib/group") { FOREACH_STRING(fname, "/etc/group", "/usr/lib/group") {
_cleanup_fclose_ FILE *f = NULL; _cleanup_fclose_ FILE *f = NULL;