commit de175e628732df88616807e77bec14677af57717
parent 2f4fa5e7ce04f2025597e0f2747f2ece3d2398ba
Author: Friedel Schön <[email protected]>
Date:   Sun,  7 May 2023 23:24:59 +0200
merging fsvc-lsb into fsvc.c
Diffstat:
2 files changed, 22 insertions(+), 57 deletions(-)
diff --git a/src/exec/fsvc.c b/src/exec/fsvc.c
@@ -4,6 +4,7 @@
 
 #include <ctype.h>
 #include <getopt.h>
+#include <libgen.h>
 #include <stdio.h>
 #include <stdlib.h>
 #include <string.h>
@@ -12,6 +13,7 @@
 static const char HELP_MESSAGE[] =
     "Usage:\n"
     "  %s <command> [-cfopqvV] [-r ..] [-s ..] [service]\n"
+    "  /etc/init.d/<service> [-cfopqvV] [-r ..] [-s ..] <command>\n"
     "\n"
     "Check the manual (fsvc 8) for more information.\n";
 
@@ -150,6 +152,8 @@ int main(int argc, char** argv) {
 	strcpy(runlevel, getenv(SV_RUNLEVEL_ENV) ?: SV_RUNLEVEL);
 	service_dir = SV_SERVICE_DIR;
 
+	char* argexec = argv[0];
+
 	bool check = false,
 	     pin   = false,
 	     once  = false,
@@ -205,92 +209,73 @@ int main(int argc, char** argv) {
 	}
 
 	const char* command_str = argv[0];
-	argv++;
-	argc--;
+	argv++, argc--;
 
-	const char* service = NULL;
+	const char* service;
 	char        command, extra = 0;
 
+	if (streq(service = basename(argexec), "fsvc")) {
+		if (argc > 0) {
+			service = argv[0];
+			argv++, argc--;
+		} else {
+			service = NULL;
+		}
+	}
+
 	if (streq(command_str, "up") || streq(command_str, "start") || streq(command_str, "down") || streq(command_str, "stop")) {
-		if (argc == 0) {
+		if (!service) {
 			printf("service omitted\n");
 			return 1;
-		} else if (argc > 1) {
-			printf("redundant argument '%s'\n", argv[2]);
-			return 1;
 		}
 
 		command = streq(command_str, "down") || streq(command_str, "stop") ? S_STOP : S_START;
 		extra   = pin;
-		service = argv[0];
 		pin     = false;
 	} else if (streq(command_str, "send") || streq(command_str, "kill")) {
-		if (argc == 0) {
+		if (!service) {
 			printf("service omitted\n");
 			return 1;
-		} else if (argc == 1) {
+		}
+		if (argc == 1) {
 			printf("signal omitted\n");
 			return 1;
-		} else if (argc > 2) {
-			printf("redundant argument '%s'\n", argv[2]);
-			return 1;
 		}
-
 		if ((extra = signame(argv[1])) == -1) {
 			printf("unknown signalname\n");
 			return 1;
 		}
 
 		command = S_SEND;
-		service = argv[0];
 	} else if (streq(command_str, "enable") || streq(command_str, "disable")) {
-		if (argc == 0) {
+		if (!service) {
 			printf("service omitted\n");
 			return 1;
-		} else if (argc > 1) {
-			printf("redundant argument '%s'\n", argv[2]);
-			return 1;
 		}
 
 		command = streq(command_str, "enable") ? S_ENABLE : S_DISABLE;
 		extra   = once;
 		once    = false;
-		service = argv[0];
 	} else if (streq(command_str, "status")) {
-		if (argc == 1) {
-			service = argv[0];
-		} else if (argc > 1) {
-			printf("redundant argument '%s'\n", argv[2]);
-			return 1;
-		}
-
 		command = S_STATUS;
 		extra   = check;
 		check   = false;
 	} else if (streq(command_str, "pause") || streq(command_str, "resume")) {
-		if (argc == 0) {
+		if (!service) {
 			printf("service omitted\n");
 			return 1;
-		} else if (argc > 1) {
-			printf("redundant argument '%s'\n", argv[2]);
-			return 1;
 		}
 
 		command = streq(command_str, "pause") ? S_PAUSE : S_RESUME;
-		service = argv[0];
 	} else if (streq(command_str, "switch")) {
-		if (argc == 0) {
+		if (!service) {
 			printf("runlevel omitted\n");
 			return 1;
-		} else if (argc > 1) {
-			printf("redundant argument '%s'\n", argv[2]);
-			return 1;
 		}
 
 		command = S_SWITCH;
 		extra   = reset;
 		reset   = false;
-		service = argv[0];
 	} else {
 		printf("unknown command '%s'\n", command_str);
 		return 1;
diff --git a/src/script/fsvc-lsb.sh b/src/script/fsvc-lsb.sh
@@ -1,19 +0,0 @@
-#!/bin/sh
-
-fsvc=/sbin/fsvc
-fsvc_lsb=fsvc-lsb
-
-name=$(basename $0)
-
-if [ "$name" = "$fsvc_lsb" ]; then
-	echo "warning: calling fsvs-lsb without service"
-	echo "  probabally this will cause an error but maybe it's intentionally"
-fi
-
-if [ -z "$1" ]; then 
-	echo "error: missing <command>"
-	echo "usage: $0 <command>"
-	exit 1
-fi
-
-exec $fsvc $name $1 
-\ No newline at end of file