aboutsummaryrefslogtreecommitdiff
path: root/src/librc-daemon.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/librc-daemon.c')
-rw-r--r--src/librc-daemon.c68
1 files changed, 36 insertions, 32 deletions
diff --git a/src/librc-daemon.c b/src/librc-daemon.c
index 5b1e0239..42192f45 100644
--- a/src/librc-daemon.c
+++ b/src/librc-daemon.c
@@ -147,7 +147,7 @@ pid_t *rc_find_pids (const char *exec, const char *cmd,
librc_hidden_def(rc_find_pids)
#elif defined(__DragonFly__) || defined(__FreeBSD__) || \
- defined(__NetBSD__) || defined(__OpenBSD__)
+ defined(__NetBSD__) || defined(__OpenBSD__)
# if defined(__DragonFly__) || defined(__FreeBSD__)
# ifndef KERN_PROC_PROC
@@ -228,9 +228,9 @@ librc_hidden_def(rc_find_pids)
# error "Platform not supported!"
#endif
-static bool _match_daemon (const char *path, const char *file,
- const char *mexec, const char *mname,
- const char *mpidfile)
+static int _match_daemon (const char *path, const char *file,
+ const char *mexec, const char *mname,
+ const char *mpidfile)
{
char buffer[RC_LINEBUFFER];
char *ffile = rc_strcatpaths (path, file, (char *) NULL);
@@ -238,15 +238,15 @@ static bool _match_daemon (const char *path, const char *file,
int lc = 0;
int m = 0;
- if (! rc_exists (ffile)) {
+ if (rc_exists (ffile) != 0) {
free (ffile);
- return (false);
+ return (-1);
}
if ((fp = fopen (ffile, "r")) == NULL) {
eerror ("fopen `%s': %s", ffile, strerror (errno));
free (ffile);
- return (false);
+ return (-1);
}
if (! mname)
@@ -277,12 +277,12 @@ static bool _match_daemon (const char *path, const char *file,
fclose (fp);
free (ffile);
- return (m == 111 ? true : false);
+ return (m == 111 ? 0 : -1);
}
-void rc_set_service_daemon (const char *service, const char *exec,
- const char *name, const char *pidfile,
- bool started)
+int rc_set_service_daemon (const char *service, const char *exec,
+ const char *name, const char *pidfile,
+ bool started)
{
char *svc = rc_xstrdup (service);
char *dirpath = rc_strcatpaths (RC_SVCDIR, "daemons", basename (svc),
@@ -295,10 +295,11 @@ void rc_set_service_daemon (const char *service, const char *exec,
char *mname;
char *mpidfile;
int nfiles = 0;
+ int retval = -1;
free (svc);
if (! exec && ! name && ! pidfile)
- return;
+ return (-1);
if (exec) {
i = strlen (exec) + 6;
@@ -322,7 +323,7 @@ void rc_set_service_daemon (const char *service, const char *exec,
mpidfile = rc_xstrdup ("pidfile=");
/* Regardless, erase any existing daemon info */
- if (rc_is_dir (dirpath)) {
+ if (rc_is_dir (dirpath) == 0) {
char *oldfile = NULL;
files = rc_ls_dir (dirpath, 0);
STRLIST_FOREACH (files, file, i) {
@@ -330,7 +331,7 @@ void rc_set_service_daemon (const char *service, const char *exec,
nfiles++;
if (! oldfile) {
- if (_match_daemon (dirpath, file, mexec, mname, mpidfile)) {
+ if (_match_daemon (dirpath, file, mexec, mname, mpidfile) == 0) {
unlink (ffile);
oldfile = ffile;
nfiles--;
@@ -350,7 +351,7 @@ void rc_set_service_daemon (const char *service, const char *exec,
char buffer[10];
FILE *fp;
- if (! rc_is_dir (dirpath))
+ if (rc_is_dir (dirpath) != 0)
if (mkdir (dirpath, 0755) != 0)
eerror ("mkdir `%s': %s", dirpath, strerror (errno));
@@ -360,6 +361,7 @@ void rc_set_service_daemon (const char *service, const char *exec,
eerror ("fopen `%s': %s", file, strerror (errno));
else {
fprintf (fp, "%s\n%s\n%s\n", mexec, mname, mpidfile);
+ retval = 0;
fclose (fp);
}
free (file);
@@ -369,30 +371,32 @@ void rc_set_service_daemon (const char *service, const char *exec,
free (mname);
free (mpidfile);
free (dirpath);
+
+ return (retval);
}
librc_hidden_def(rc_set_service_daemon)
-bool rc_service_started_daemon (const char *service, const char *exec,
- int indx)
+int rc_service_started_daemon (const char *service, const char *exec,
+ int indx)
{
char *dirpath;
char *file;
int i;
char *mexec;
- bool retval = false;
+ int retval = -1;
char *svc;
if (! service || ! exec)
- return (false);
+ return (-1);
svc = rc_xstrdup (service);
dirpath = rc_strcatpaths (RC_SVCDIR, "daemons", basename (svc),
(char *) NULL);
free (svc);
- if (! rc_is_dir (dirpath)) {
+ if (rc_is_dir (dirpath) != 0) {
free (dirpath);
- return (false);
+ return (-1);
}
i = strlen (exec) + 6;
@@ -409,7 +413,7 @@ bool rc_service_started_daemon (const char *service, const char *exec,
char **files = rc_ls_dir (dirpath, 0);
STRLIST_FOREACH (files, file, i) {
retval = _match_daemon (dirpath, file, mexec, NULL, NULL);
- if (retval)
+ if (retval == 0)
break;
}
rc_strlist_free (files);
@@ -420,7 +424,7 @@ bool rc_service_started_daemon (const char *service, const char *exec,
}
librc_hidden_def(rc_service_started_daemon)
-bool rc_service_daemons_crashed (const char *service)
+int rc_service_daemons_crashed (const char *service)
{
char *dirpath;
char **files;
@@ -436,20 +440,20 @@ bool rc_service_daemons_crashed (const char *service)
pid_t *pids = NULL;
char *p;
char *token;
- bool retval = false;
+ int retval = -1;
char *svc;
if (! service)
- return (false);
+ return (-1);
svc = rc_xstrdup (service);
dirpath = rc_strcatpaths (RC_SVCDIR, "daemons", basename (svc),
(char *) NULL);
free (svc);
- if (! rc_is_dir (dirpath)) {
+ if (rc_is_dir (dirpath) != 0) {
free (dirpath);
- return (false);
+ return (-1);
}
memset (buffer, 0, sizeof (buffer));
@@ -493,21 +497,21 @@ bool rc_service_daemons_crashed (const char *service)
pid = 0;
if (pidfile) {
- if (! rc_exists (pidfile)) {
- retval = true;
+ if (rc_exists (pidfile) != 0) {
+ retval = 0;
break;
}
if ((fp = fopen (pidfile, "r")) == NULL) {
eerror ("fopen `%s': %s", pidfile, strerror (errno));
- retval = true;
+ retval = 0;
break;
}
if (fscanf (fp, "%d", &pid) != 1) {
eerror ("no pid found in `%s'", pidfile);
fclose (fp);
- retval = true;
+ retval = 0;
break;
}
@@ -523,7 +527,7 @@ bool rc_service_daemons_crashed (const char *service)
}
if ((pids = rc_find_pids (exec, name, 0, pid)) == NULL) {
- retval = true;
+ retval = 0;
break;
}
free (pids);