From: Zbigniew Jędrzejewski-Szmek Date: Tue, 27 Nov 2018 14:23:35 +0000 (+0100) Subject: rc-local-generator: use macro to define main() X-Git-Tag: v240~203^2~1 X-Git-Url: http://git.ipfire.org/gitweb.cgi?a=commitdiff_plain;h=1332ecb8ad3565aec22c0c863f0c1576aa40645e;p=thirdparty%2Fsystemd.git rc-local-generator: use macro to define main() --- diff --git a/src/rc-local-generator/rc-local-generator.c b/src/rc-local-generator/rc-local-generator.c index a8dc68bccca..b7cb04fc6fa 100644 --- a/src/rc-local-generator/rc-local-generator.c +++ b/src/rc-local-generator/rc-local-generator.c @@ -6,6 +6,7 @@ #include "generator.h" #include "log.h" +#include "main-func.h" #include "mkdir.h" #include "string-util.h" #include "util.h" @@ -41,32 +42,30 @@ static int add_symlink(const char *service, const char *where) { return 1; } -int main(int argc, char *argv[]) { - int ret = EXIT_SUCCESS; +static int run(int argc, char *argv[]) { + int r = 0, k = 0; - if (argc > 1 && argc != 4) { - log_error("This program takes three or no arguments."); - return EXIT_FAILURE; - } + log_setup_generator(); + + if (argc > 1 && argc != 4) + return log_error_errno(SYNTHETIC_ERRNO(EINVAL), "This program takes three or no arguments."); if (argc > 1) arg_dest = argv[1]; - log_setup_generator(); - if (access(RC_LOCAL_SCRIPT_PATH_START, X_OK) >= 0) { log_debug("Automatically adding rc-local.service."); - if (add_symlink("rc-local.service", "multi-user.target") < 0) - ret = EXIT_FAILURE; + r = add_symlink("rc-local.service", "multi-user.target"); } if (access(RC_LOCAL_SCRIPT_PATH_STOP, X_OK) >= 0) { log_debug("Automatically adding halt-local.service."); - if (add_symlink("halt-local.service", "final.target") < 0) - ret = EXIT_FAILURE; + k = add_symlink("halt-local.service", "final.target"); } - return ret; + return r < 0 ? r : k; } + +DEFINE_MAIN_FUNCTION(run);