diff options
author | David Oberhollenzer <david.oberhollenzer@tele2.at> | 2018-03-25 01:55:08 +0100 |
---|---|---|
committer | David Oberhollenzer <david.oberhollenzer@tele2.at> | 2018-03-25 01:55:08 +0100 |
commit | f97add9041c7cf330d2743b1dca9267676bdaa72 (patch) | |
tree | 7b1a5b4418367e1462d912cdff17a1b2d1173c37 /lib/src/rdsrv.c | |
parent | 9257f12e68794a557496637e2fa951738a37af26 (diff) |
Add file with service enum conversion functions
Signed-off-by: David Oberhollenzer <david.oberhollenzer@tele2.at>
Diffstat (limited to 'lib/src/rdsrv.c')
-rw-r--r-- | lib/src/rdsrv.c | 27 |
1 files changed, 6 insertions, 21 deletions
diff --git a/lib/src/rdsrv.c b/lib/src/rdsrv.c index ec60ce1..88d41e8 100644 --- a/lib/src/rdsrv.c +++ b/lib/src/rdsrv.c @@ -27,21 +27,6 @@ #include "service.h" #include "util.h" -static const enum_map_t type_map[] = { - { "once", SVC_ONCE }, - { "wait", SVC_WAIT }, - { "respawn", SVC_RESPAWN }, - { NULL, 0 }, -}; - -static const enum_map_t target_map[] = { - { "boot", TGT_BOOT }, - { "shutdown", TGT_SHUTDOWN }, - { "reboot", TGT_REBOOT }, - { "ctrlaltdel", TGT_CAD }, - { NULL, 0 }, -}; - static int srv_name(service_t *srv, char *arg, const char *filename, size_t lineno) { @@ -118,15 +103,15 @@ static int srv_after(service_t *srv, char *arg, static int srv_type(service_t *srv, char *arg, const char *filename, size_t lineno) { - const enum_map_t *ent = enum_by_name(type_map, arg); + int type = svc_type_from_string(arg); - if (ent == NULL) { + if (type == -1) { fprintf(stderr, "%s: %zu: unknown service type '%s'\n", filename, lineno, arg); return -1; } - srv->type = ent->value; + srv->type = type; free(arg); return 0; } @@ -134,15 +119,15 @@ static int srv_type(service_t *srv, char *arg, static int srv_target(service_t *srv, char *arg, const char *filename, size_t lineno) { - const enum_map_t *ent = enum_by_name(target_map, arg); + int target = svc_target_from_string(arg); - if (ent == NULL) { + if (target == -1) { fprintf(stderr, "%s: %zu: unknown service target '%s'\n", filename, lineno, arg); return -1; } - srv->target = ent->value; + srv->target = target; free(arg); return 0; } |