diff options
author | Yu Watanabe <watanabe.yu+github@gmail.com> | 2023-04-12 16:43:39 +0900 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-04-12 16:43:39 +0900 |
commit | f643ca1767a52918c69c324f2ed6dbdfa005f04e (patch) | |
tree | 0a440c3cee3f0ac20fb9a94a98af5ebcef8c014e /src/systemctl | |
parent | 82929336c77ee9e1b0056f25daa6a4210403d1b3 (diff) | |
parent | f86a41291b6395b9fb74ccd74911ad7867d81dd9 (diff) | |
download | systemd-f643ca1767a52918c69c324f2ed6dbdfa005f04e.tar.gz |
Merge pull request #27033 from dtardon/array-cleanup
Use CLEANUP_ARRAY more
Diffstat (limited to 'src/systemctl')
-rw-r--r-- | src/systemctl/systemctl-add-dependency.c | 25 | ||||
-rw-r--r-- | src/systemctl/systemctl-enable.c | 21 | ||||
-rw-r--r-- | src/systemctl/systemctl-preset-all.c | 20 | ||||
-rw-r--r-- | src/systemctl/systemctl-set-default.c | 15 |
4 files changed, 34 insertions, 47 deletions
diff --git a/src/systemctl/systemctl-add-dependency.c b/src/systemctl/systemctl-add-dependency.c index 4bbcd7a13b..b0bed577cc 100644 --- a/src/systemctl/systemctl-add-dependency.c +++ b/src/systemctl/systemctl-add-dependency.c @@ -16,6 +16,8 @@ int verb_add_dependency(int argc, char *argv[], void *userdata) { UnitDependency dep; int r; + CLEANUP_ARRAY(changes, n_changes, install_changes_free); + if (!argv[1]) return 0; @@ -39,9 +41,8 @@ int verb_add_dependency(int argc, char *argv[], void *userdata) { if (install_client_side()) { r = unit_file_add_dependency(arg_runtime_scope, unit_file_flags_from_args(), arg_root, names, target, dep, &changes, &n_changes); install_changes_dump(r, "add dependency on", changes, n_changes, arg_quiet); - - if (r > 0) - r = 0; + if (r < 0) + return r; } else { _cleanup_(sd_bus_message_unrefp) sd_bus_message *reply = NULL, *m = NULL; _cleanup_(sd_bus_error_free) sd_bus_error error = SD_BUS_ERROR_NULL; @@ -71,20 +72,14 @@ int verb_add_dependency(int argc, char *argv[], void *userdata) { r = bus_deserialize_and_dump_unit_file_changes(reply, arg_quiet, &changes, &n_changes); if (r < 0) - goto finish; + return r; - if (arg_no_reload) { - r = 0; - goto finish; + if (!arg_no_reload) { + r = daemon_reload(ACTION_RELOAD, /* graceful= */ false); + if (r < 0) + return r; } - - r = daemon_reload(ACTION_RELOAD, /* graceful= */ false); - if (r > 0) - r = 0; } -finish: - install_changes_free(changes, n_changes); - - return r; + return 0; } diff --git a/src/systemctl/systemctl-enable.c b/src/systemctl/systemctl-enable.c index 0cc8cbb6b8..2fc5a0b051 100644 --- a/src/systemctl/systemctl-enable.c +++ b/src/systemctl/systemctl-enable.c @@ -70,6 +70,8 @@ int verb_enable(int argc, char *argv[], void *userdata) { bool ignore_carries_install_info = arg_quiet || arg_no_warn; int r; + CLEANUP_ARRAY(changes, n_changes, install_changes_free); + if (!argv[1]) return 0; @@ -130,8 +132,7 @@ int verb_enable(int argc, char *argv[], void *userdata) { install_changes_dump(r, verb, changes, n_changes, arg_quiet); if (r < 0) - goto finish; - r = 0; + return r; } else { _cleanup_(sd_bus_message_unrefp) sd_bus_message *reply = NULL, *m = NULL; _cleanup_(sd_bus_error_free) sd_bus_error error = SD_BUS_ERROR_NULL; @@ -236,15 +237,14 @@ int verb_enable(int argc, char *argv[], void *userdata) { r = bus_deserialize_and_dump_unit_file_changes(reply, arg_quiet, &changes, &n_changes); if (r < 0) - goto finish; + return r; /* Try to reload if enabled */ if (!arg_no_reload) { r = daemon_reload(ACTION_RELOAD, /* graceful= */ false); - if (r > 0) - r = 0; - } else - r = 0; + if (r < 0) + return r; + } } if (carries_install_info == 0 && !ignore_carries_install_info) @@ -306,7 +306,7 @@ int verb_enable(int argc, char *argv[], void *userdata) { r = acquire_bus(BUS_MANAGER, &bus); if (r < 0) - goto finish; + return r; len = strv_length(names); { @@ -321,8 +321,5 @@ int verb_enable(int argc, char *argv[], void *userdata) { } } -finish: - install_changes_free(changes, n_changes); - - return r; + return 0; } diff --git a/src/systemctl/systemctl-preset-all.c b/src/systemctl/systemctl-preset-all.c index ed117e077c..70e302e126 100644 --- a/src/systemctl/systemctl-preset-all.c +++ b/src/systemctl/systemctl-preset-all.c @@ -12,6 +12,8 @@ int verb_preset_all(int argc, char *argv[], void *userdata) { size_t n_changes = 0; int r; + CLEANUP_ARRAY(changes, n_changes, install_changes_free); + if (install_client_side()) { r = unit_file_preset_all(arg_runtime_scope, unit_file_flags_from_args(), arg_root, arg_preset_mode, &changes, &n_changes); install_changes_dump(r, "preset", changes, n_changes, arg_quiet); @@ -44,20 +46,14 @@ int verb_preset_all(int argc, char *argv[], void *userdata) { r = bus_deserialize_and_dump_unit_file_changes(reply, arg_quiet, &changes, &n_changes); if (r < 0) - goto finish; + return r; - if (arg_no_reload) { - r = 0; - goto finish; + if (!arg_no_reload) { + r = daemon_reload(ACTION_RELOAD, /* graceful= */ false); + if (r < 0) + return r; } - - r = daemon_reload(ACTION_RELOAD, /* graceful= */ false); - if (r > 0) - r = 0; } -finish: - install_changes_free(changes, n_changes); - - return r; + return 0; } diff --git a/src/systemctl/systemctl-set-default.c b/src/systemctl/systemctl-set-default.c index 28886c8356..55f696565e 100644 --- a/src/systemctl/systemctl-set-default.c +++ b/src/systemctl/systemctl-set-default.c @@ -102,6 +102,8 @@ int verb_set_default(int argc, char *argv[], void *userdata) { assert(argc >= 2); assert(argv); + CLEANUP_ARRAY(changes, n_changes, install_changes_free); + r = unit_name_mangle_with_suffix(argv[1], "set-default", arg_quiet ? 0 : UNIT_NAME_MANGLE_WARN, ".target", &unit); @@ -112,7 +114,7 @@ int verb_set_default(int argc, char *argv[], void *userdata) { r = unit_file_set_default(arg_runtime_scope, UNIT_FILE_FORCE, arg_root, unit, &changes, &n_changes); install_changes_dump(r, "set default", changes, n_changes, arg_quiet); if (r < 0) - goto finish; + return r; } else { _cleanup_(sd_bus_error_free) sd_bus_error error = SD_BUS_ERROR_NULL; _cleanup_(sd_bus_message_unrefp) sd_bus_message *reply = NULL; @@ -130,13 +132,13 @@ int verb_set_default(int argc, char *argv[], void *userdata) { r = bus_deserialize_and_dump_unit_file_changes(reply, arg_quiet, &changes, &n_changes); if (r < 0) - goto finish; + return r; /* Try to reload if enabled */ if (!arg_no_reload) { r = daemon_reload(ACTION_RELOAD, /* graceful= */ false); if (r < 0) - goto finish; + return r; } } @@ -147,14 +149,11 @@ int verb_set_default(int argc, char *argv[], void *userdata) { r = determine_default(&final); if (r < 0) - goto finish; + return r; if (!streq(final, unit)) log_notice("Note: \"%s\" is the default unit (possibly a runtime override).", final); } -finish: - install_changes_free(changes, n_changes); - - return r < 0 ? r : 0; + return 0; } |