aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJason Felice <jason.m.felice@gmail.com>2019-10-29 10:07:10 -0400
committerDan Cross <crossd@gmail.com>2019-10-29 10:07:10 -0400
commitb0aecb4ba5c3d7df6589c01f5a7c0427f5a75305 (patch)
tree09f1a1b702365ee8a01d3c6e0de5f10740213526
parent1309450668aa571dee97f4373f9555b4fddcf1aa (diff)
downloadplan9port-b0aecb4ba5c3d7df6589c01f5a7c0427f5a75305.tar.gz
plan9port-b0aecb4ba5c3d7df6589c01f5a7c0427f5a75305.tar.bz2
plan9port-b0aecb4ba5c3d7df6589c01f5a7c0427f5a75305.zip
plumber: add -f (foreground) option (#288)
In MacOS, services run by launchd must run in the foreground, since launchd manages forking and other resources.
-rw-r--r--man/man4/plumber.49
-rw-r--r--src/cmd/plumb/fsys.c7
-rw-r--r--src/cmd/plumb/plumber.c6
-rw-r--r--src/cmd/plumb/plumber.h2
4 files changed, 19 insertions, 5 deletions
diff --git a/man/man4/plumber.4 b/man/man4/plumber.4
index 0dfe68bb..88801eb4 100644
--- a/man/man4/plumber.4
+++ b/man/man4/plumber.4
@@ -4,6 +4,9 @@ plumber \- file system for interprocess messaging
.SH SYNOPSIS
.B plumber
[
+.B -f
+]
+[
.B -p
.I plumbing
]
@@ -23,7 +26,7 @@ in the format of
Its services are posted via
.IR 9pserve (4)
as
-.BR plumb .
+.BR plumb ,
and consist of two
pre-defined files,
.B plumb/send
@@ -95,6 +98,10 @@ Thus the rule set may be edited dynamically with a traditional text editor.
However, ports are never deleted dynamically; if a new set of rules does not
include a port that was defined in earlier rules, that port will still exist (although
no new messages will be delivered there).
+.PP
+The
+.B -f
+option causes the process to run in the foreground.
.SH FILES
.TF $HOME/lib/plumbing
.TP
diff --git a/src/cmd/plumb/fsys.c b/src/cmd/plumb/fsys.c
index 51542674..63106fcd 100644
--- a/src/cmd/plumb/fsys.c
+++ b/src/cmd/plumb/fsys.c
@@ -186,7 +186,7 @@ getclock(void)
}
void
-startfsys(void)
+startfsys(int foreground)
{
int p[2];
@@ -199,7 +199,10 @@ startfsys(void)
if(post9pservice(p[1], "plumb", nil) < 0)
sysfatal("post9pservice plumb: %r");
close(p[1]);
- proccreate(fsysproc, nil, Stack);
+ if(foreground)
+ fsysproc(nil);
+ else
+ proccreate(fsysproc, nil, Stack);
}
static void
diff --git a/src/cmd/plumb/plumber.c b/src/cmd/plumb/plumber.c
index 2debf49b..c99282f0 100644
--- a/src/cmd/plumb/plumber.c
+++ b/src/cmd/plumb/plumber.c
@@ -7,6 +7,7 @@
#include "plumber.h"
int debug;
+int foreground=0;
char *plumbfile;
char *user;
char *home;
@@ -37,6 +38,9 @@ threadmain(int argc, char *argv[])
case 'd':
debug = 1;
break;
+ case 'f':
+ foreground = 1;
+ break;
case 'p':
plumbfile = ARGF();
break;
@@ -69,7 +73,7 @@ threadmain(int argc, char *argv[])
*/
printerrors = 0;
makeports(rules);
- startfsys();
+ startfsys(foreground);
threadexits(nil);
}
diff --git a/src/cmd/plumb/plumber.h b/src/cmd/plumb/plumber.h
index c8f30816..44700559 100644
--- a/src/cmd/plumb/plumber.h
+++ b/src/cmd/plumb/plumber.h
@@ -72,7 +72,7 @@ void* emalloc(long);
void* erealloc(void*, long);
char* estrdup(char*);
Ruleset** readrules(char*, int);
-void startfsys(void);
+void startfsys(int);
Exec* matchruleset(Plumbmsg*, Ruleset*);
void freeexec(Exec*);
char* startup(Ruleset*, Exec*);