aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-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*);