diff options
author | Laurent Bercot <ska-skaware@skarnet.org> | 2019-01-31 20:33:42 +0000 |
---|---|---|
committer | Laurent Bercot <ska-skaware@skarnet.org> | 2019-01-31 20:33:42 +0000 |
commit | 6f9dc69704211a6123b225036bffb46c1a2d6e83 (patch) | |
tree | a81ae66206510363b76f496fcef267236834bb7c | |
parent | c3f9dfe79b0eccf9b87a5cd6a0b3b1b62f964348 (diff) | |
download | s6-6f9dc69704211a6123b225036bffb46c1a2d6e83.tar.gz s6-6f9dc69704211a6123b225036bffb46c1a2d6e83.tar.xz s6-6f9dc69704211a6123b225036bffb46c1a2d6e83.zip |
Make "s6-svc -wu foo" wait for foo to be up. Document supervise/ creation.
-rw-r--r-- | doc/s6-supervise.html | 2 | ||||
-rw-r--r-- | src/libs6/s6_svc_write.c | 29 | ||||
-rw-r--r-- | src/supervision/s6-svc.c | 14 |
3 files changed, 26 insertions, 19 deletions
diff --git a/doc/s6-supervise.html b/doc/s6-supervise.html index f5cb269..2926f83 100644 --- a/doc/s6-supervise.html +++ b/doc/s6-supervise.html @@ -122,6 +122,8 @@ the service stops, as if a <ul> <li> s6-supervise switches to the <em>servicedir</em> <a href="servicedir.html">service directory</a>. </li> + <li> It creates a <tt>supervise/</tt> subdirectory (if it doesn't exist yet) to +store its internal data. </li> <li> It exits 100 if another s6-supervise process is already monitoring this service. </li> <li> If the <tt>./event</tt> <a href="fifodir.html">fifodir</a> does not exist, s6-supervise creates it and allows subscriptions to it from processes having the same diff --git a/src/libs6/s6_svc_write.c b/src/libs6/s6_svc_write.c index 70c3964..46d3178 100644 --- a/src/libs6/s6_svc_write.c +++ b/src/libs6/s6_svc_write.c @@ -7,21 +7,24 @@ int s6_svc_write (char const *fifo, char const *data, size_t datalen) { - int fd = open_write(fifo) ; - if (fd < 0) switch (errno) - { - case ENXIO : return 0 ; - case ENOENT : - case ENOTDIR : - case EISDIR : return -2 ; - default : return -1 ; - } - if (ndelay_off(fd) == -1) return -1 ; - if (fd_write(fd, data, datalen) == -1) + if (datalen) { + int fd = open_write(fifo) ; + if (fd < 0) switch (errno) + { + case ENXIO : return 0 ; + case ENOENT : + case ENOTDIR : + case EISDIR : return -2 ; + default : return -1 ; + } + if (ndelay_off(fd) == -1) return -1 ; + if (fd_write(fd, data, datalen) == -1) + { + fd_close(fd) ; + return -1 ; + } fd_close(fd) ; - return -1 ; } - fd_close(fd) ; return 1 ; } diff --git a/src/supervision/s6-svc.c b/src/supervision/s6-svc.c index ee7ddc5..6a5d64b 100644 --- a/src/supervision/s6-svc.c +++ b/src/supervision/s6-svc.c @@ -69,7 +69,6 @@ int main (int argc, char const *const *argv, char const *const *envp) if (!argc) dieusage() ; if (argc > 1) strerr_warn1x("ignoring extra arguments") ; - if (datalen <= 1) return 0 ; if (updown[1] == 'U' || updown[1] == 'R') { size_t arglen = strlen(argv[0]) ; @@ -89,7 +88,7 @@ int main (int argc, char const *const *argv, char const *const *envp) char const *newargv[11] ; unsigned int m = 0 ; char fmt[UINT_FMT] ; - newargv[m++] = S6_BINPREFIX "s6-svlisten1" ; + newargv[m++] = datalen > 1 ? S6_BINPREFIX "s6-svlisten1" : S6_BINPREFIX "s6-svwait" ; newargv[m++] = updown ; if (timeout) { @@ -99,10 +98,13 @@ int main (int argc, char const *const *argv, char const *const *envp) } newargv[m++] = "--" ; newargv[m++] = argv[0] ; - newargv[m++] = S6_BINPREFIX "s6-svc" ; - newargv[m++] = data ; - newargv[m++] = "--" ; - newargv[m++] = argv[0] ; + if (datalen > 1) + { + newargv[m++] = S6_BINPREFIX "s6-svc" ; + newargv[m++] = data ; + newargv[m++] = "--" ; + newargv[m++] = argv[0] ; + } newargv[m++] = 0 ; xpathexec_run(newargv[0], newargv, envp) ; } |