]> git.ipfire.org Git - thirdparty/systemd.git/commitdiff
boot-check-no-failures: define main through macro
authorZbigniew Jędrzejewski-Szmek <zbyszek@in.waw.pl>
Fri, 16 Nov 2018 09:44:36 +0000 (10:44 +0100)
committerZbigniew Jędrzejewski-Szmek <zbyszek@in.waw.pl>
Sat, 17 Nov 2018 08:13:35 +0000 (09:13 +0100)
src/boot/boot-check-no-failures.c

index e7884461c64558a7a97d64e77a7994cf8aecf6af..1674517d4878cef5c72072387845e498f27c8e42 100644 (file)
@@ -61,7 +61,7 @@ static int parse_argv(int argc, char *argv[]) {
         return 1;
 }
 
-int main(int argc, char *argv[]) {
+static int run(int argc, char *argv[]) {
         _cleanup_(sd_bus_error_free) sd_bus_error error = SD_BUS_ERROR_NULL;
         _cleanup_(sd_bus_flush_close_unrefp) sd_bus *bus = NULL;
         uint32_t n;
@@ -72,13 +72,11 @@ int main(int argc, char *argv[]) {
 
         r = parse_argv(argc, argv);
         if (r <= 0)
-                goto finish;
+                return r;
 
         r = sd_bus_open_system(&bus);
-        if (r < 0) {
-                log_error_errno(r, "Failed to connect to system bus: %m");
-                goto finish;
-        }
+        if (r < 0)
+                return log_error_errno(r, "Failed to connect to system bus: %m");
 
         r = sd_bus_get_property_trivial(
                         bus,
@@ -89,18 +87,15 @@ int main(int argc, char *argv[]) {
                         &error,
                         'u',
                         &n);
-        if (r < 0) {
-                log_error_errno(r, "Failed to get failed units counter: %s", bus_error_message(&error, r));
-                goto finish;
-        }
+        if (r < 0)
+                return log_error_errno(r, "Failed to get failed units counter: %s", bus_error_message(&error, r));
 
         if (n > 0)
                 log_notice("Health check: %" PRIu32 " units have failed.", n);
         else
                 log_info("Health check: no failed units.");
 
-        r = n > 0 ? EXIT_FAILURE : EXIT_SUCCESS;
-
-finish:
-        return r < 0 ? EXIT_FAILURE : r;
+        return n > 0;
 }
+
+DEFINE_MAIN_FUNCTION_WITH_POSITIVE_FAILURE(run);