aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--initd/main.c49
1 files changed, 34 insertions, 15 deletions
diff --git a/initd/main.c b/initd/main.c
index c804105..d8319ea 100644
--- a/initd/main.c
+++ b/initd/main.c
@@ -1,17 +1,36 @@
/* SPDX-License-Identifier: ISC */
#include "init.h"
-static const char *status_str[] = {
- [STATE_OFF] = NULL,
- [STATE_QUEUED] = NULL,
- [STATE_RUNNING] ="\033[22;33m UP \033[0m",
- [STATE_COMPLETED] = "\033[22;32mDONE\033[0m",
- [STATE_FAILED] ="\033[22;31mFAIL\033[0m",
-};
-
-static void print_status(const char *msg, int type)
+static void print_status(svc_run_data_t *rt)
{
- printf("[%s] %s\n", status_str[type], msg);
+ const char *str;
+ char pre = '\n';
+
+ switch (rt->state) {
+ case STATE_RUNNING:
+ if (rt->svc->type == SVC_WAIT) {
+ str = "\033[22;33m .. \033[0m";
+ } else {
+ str = "\033[22;32m UP \033[0m";
+ }
+ break;
+ case STATE_COMPLETED:
+ if (rt->svc->type == SVC_WAIT)
+ pre = '\r';
+
+ str = "\033[22;32mDONE\033[0m";
+ break;
+ case STATE_FAILED:
+ if (rt->svc->type == SVC_WAIT)
+ pre = '\r';
+
+ str = "\033[22;31mFAIL\033[0m";
+ break;
+ default:
+ return;
+ }
+
+ printf("%c[%s] %s", pre, str, rt->svc->desc);
fflush(stdout);
}
@@ -32,7 +51,7 @@ static void respawn(svc_run_data_t *rt)
return;
fail:
rt->state = STATE_FAILED;
- print_status(rt->svc->desc, rt->state);
+ print_status(rt);
return;
}
@@ -61,7 +80,7 @@ static svc_run_data_t *wait_for_process(void)
rt->state = STATE_FAILED;
}
- print_status(rt->svc->desc, rt->state);
+ print_status(rt);
if (rt->svc->type == SVC_ONCE)
config_singleshot_terminated();
@@ -143,10 +162,10 @@ int main(void)
if (rt->pid == -1) {
rt->state = STATE_FAILED;
- print_status(svc->desc, rt->state);
+ print_status(rt);
} else {
rt->state = STATE_RUNNING;
- print_status(svc->desc, rt->state);
+ print_status(rt);
switch (svc->type) {
case SVC_WAIT:
@@ -164,7 +183,7 @@ int main(void)
} else {
rt->status = EXIT_SUCCESS;
rt->state = STATE_COMPLETED;
- print_status(svc->desc, rt->state);
+ print_status(rt);
}
check_target_completion();