mirror of
https://github.com/9fans/plan9port.git
synced 2025-01-24 11:41:58 +00:00
plumber: add -f (foreground) option (#288)
In MacOS, services run by launchd must run in the foreground, since launchd manages forking and other resources.
This commit is contained in:
parent
1309450668
commit
b0aecb4ba5
4 changed files with 19 additions and 5 deletions
|
@ -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
|
||||
|
|
|
@ -186,7 +186,7 @@ getclock(void)
|
|||
}
|
||||
|
||||
void
|
||||
startfsys(void)
|
||||
startfsys(int foreground)
|
||||
{
|
||||
int p[2];
|
||||
|
||||
|
@ -199,6 +199,9 @@ startfsys(void)
|
|||
if(post9pservice(p[1], "plumb", nil) < 0)
|
||||
sysfatal("post9pservice plumb: %r");
|
||||
close(p[1]);
|
||||
if(foreground)
|
||||
fsysproc(nil);
|
||||
else
|
||||
proccreate(fsysproc, nil, Stack);
|
||||
}
|
||||
|
||||
|
|
|
@ -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);
|
||||
}
|
||||
|
||||
|
|
|
@ -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*);
|
||||
|
|
Loading…
Reference in a new issue