X-Git-Url: http://jsfdemo.indexdata.com/?a=blobdiff_plain;f=src%2Fmetaproxy_prog.cpp;h=c1f612306c5335d61d4f8135b21c9133012c067e;hb=235ec6eb8e28884ca223a5d451aa83b18909acd9;hp=11b04b23073902299a620f22074176d859c270d0;hpb=b078c89a9ee8e512b53560ff48cd041b25ac2cdf;p=metaproxy-moved-to-github.git diff --git a/src/metaproxy_prog.cpp b/src/metaproxy_prog.cpp index 11b04b2..c1f6123 100644 --- a/src/metaproxy_prog.cpp +++ b/src/metaproxy_prog.cpp @@ -46,22 +46,30 @@ namespace mp = metaproxy_1; mp::RouterFleXML *routerp = 0; +#if HAVE_UNISTD_H +static pid_t process_group = 0; + static void sig_term_handler(int s) { - if (routerp) - { - delete routerp; - } + kill(-process_group, SIGTERM); /* kill all children processes as well */ exit(0); } +#endif static void handler(void *data) { routerp = (mp::RouterFleXML*) data; + +#if HAVE_UNISTD_H + /* make the current working process group leader */ + setpgid(0, 0); + process_group = getpgid(0); // save process group ID signal(SIGTERM, sig_term_handler); +#endif + mp::Package pack; - pack.router(*routerp).move(); + pack.router(*routerp).move(); /* should never exit */ } static int sc_main(