From fb051bf81ac698d0618b611abc7120c32da467c3 Mon Sep 17 00:00:00 2001
From: Roy Marples <roy@marples.name>
Date: Fri, 1 May 2009 08:38:57 +0100
Subject: Add -i, --ifexists so that we can do this   rc-sercice -i foo --
 restart instead of this   rc-service -e foo && rc-service foo -- restart

---
 src/rc/rc-service.c | 25 +++++++++++++++++--------
 1 file changed, 17 insertions(+), 8 deletions(-)

(limited to 'src')

diff --git a/src/rc/rc-service.c b/src/rc/rc-service.c
index 82d4cf22..84789f3c 100644
--- a/src/rc/rc-service.c
+++ b/src/rc/rc-service.c
@@ -43,15 +43,17 @@
 extern char *applet;
 
 #include "_usage.h"
-#define getoptstring "e:lr:" getoptstring_COMMON
+#define getoptstring "e:ilr:" getoptstring_COMMON
 static const struct option longopts[] = {
-	{ "exists",  1, NULL, 'e' },
-	{ "list",    0, NULL, 'l' },
-	{ "resolve", 1, NULL, 'r' },
+	{ "exists",   1, NULL, 'e' },
+	{ "ifexists", 0, NULL, 'i' },
+	{ "list",     0, NULL, 'l' },
+	{ "resolve",  1, NULL, 'r' },
 	longopts_COMMON
 };
 static const char * const longopts_help[] = {
 	"tests if the service exists or not",
+	"if the service exsits then run the command",
 	"list all available services",
 	"resolve the service name to an init script",
 	longopts_help_COMMON
@@ -65,6 +67,7 @@ rc_service(int argc, char **argv)
 	char *service;
 	RC_STRINGLIST *list;
 	RC_STRING *s;
+	bool if_exists = false;
 
 	/* Ensure that we are only quiet when explicitly told to be */
 	unsetenv("EINFO_QUIET");
@@ -81,9 +84,12 @@ rc_service(int argc, char **argv)
 #endif
 			return opt;
 			/* NOTREACHED */
+		case 'i':
+			if_exists = true;
+			break;
 		case 'l':
 			list = rc_services_in_runlevel(NULL);
-			if (!TAILQ_FIRST(list))
+			if (TAILQ_FIRST(list) == NULL)
 				return EXIT_FAILURE;
 			rc_stringlist_sort(&list);
 			TAILQ_FOREACH(s, list, entries)
@@ -95,7 +101,7 @@ rc_service(int argc, char **argv)
 			/* NOTREACHED */
 		case 'r':
 			service = rc_service_resolve(optarg);
-			if (!service)
+			if (service == NULL)
 				return EXIT_FAILURE;
 			printf("%s\n", service);
 #ifdef DEBUG_MEMORY
@@ -110,10 +116,13 @@ rc_service(int argc, char **argv)
 
 	argc -= optind;
 	argv += optind;
-	if (!*argv)
+	if (*argv == NULL)
 		eerrorx("%s: you need to specify a service", applet);
-	if (!(service = rc_service_resolve(*argv)))
+	if ((service = rc_service_resolve(*argv)) == NULL) {
+		if (if_exists)
+			return 0;
 		eerrorx("%s: service `%s' does not exist", applet, *argv);
+	}
 	*argv = service;
 	execv(*argv, argv);
 	eerrorx("%s: %s", applet, strerror(errno));
-- 
cgit v1.2.3