2016-06-05 20:48:13 +02:00
|
|
|
#include "../lib/pubsubd.h"
|
2016-05-28 19:34:23 +02:00
|
|
|
#include <stdlib.h>
|
|
|
|
|
|
|
|
void
|
|
|
|
ohshit(int rvalue, const char* str) {
|
2016-06-04 20:33:44 +02:00
|
|
|
fprintf(stderr, "%s\n", str);
|
|
|
|
exit(rvalue);
|
2016-05-28 19:34:23 +02:00
|
|
|
}
|
|
|
|
|
2016-06-04 20:33:44 +02:00
|
|
|
int
|
|
|
|
main(int argc, char* argv[])
|
|
|
|
{
|
2016-06-05 20:48:13 +02:00
|
|
|
struct service srv;
|
|
|
|
srv_init (&srv, PUBSUB_SERVICE_NAME);
|
2016-06-06 02:25:28 +02:00
|
|
|
printf ("Listening on %s.\n", srv.spath);
|
2016-05-28 19:34:23 +02:00
|
|
|
|
2016-06-04 20:33:44 +02:00
|
|
|
// creates the service named pipe, that listens to client applications
|
2016-06-06 02:25:28 +02:00
|
|
|
if (srv_create (&srv))
|
2016-06-04 20:33:44 +02:00
|
|
|
ohshit(1, "service_create error");
|
2016-05-28 19:34:23 +02:00
|
|
|
|
2016-06-07 11:45:21 +02:00
|
|
|
// init chans list
|
2016-06-04 20:33:44 +02:00
|
|
|
struct channels chans;
|
|
|
|
pubsubd_channels_init (&chans);
|
2016-05-28 19:34:23 +02:00
|
|
|
|
2016-06-04 20:33:44 +02:00
|
|
|
for (;;) {
|
2016-06-07 11:45:21 +02:00
|
|
|
// for each new process
|
|
|
|
struct app_list_elm ale;
|
|
|
|
pubsubd_get_new_process (&srv, &ale);
|
2016-06-07 13:49:23 +02:00
|
|
|
pubsubd_app_list_elm_print (&ale);
|
|
|
|
|
|
|
|
// stop the application ? (action 3)
|
|
|
|
if (ale.action == 3) {
|
|
|
|
pubsubd_channels_del_all (&chans);
|
|
|
|
printf ("Quitting ...\n");
|
|
|
|
exit (0);
|
|
|
|
}
|
|
|
|
|
|
|
|
// add the chan to the list
|
|
|
|
|
|
|
|
// each chan has a list of subscribers
|
|
|
|
// someone who only push a msg doesn't need to be registered
|
|
|
|
|
|
|
|
//
|
2016-06-07 11:45:21 +02:00
|
|
|
|
|
|
|
// TODO thread to handle multiple clients at a time
|
2016-06-04 20:33:44 +02:00
|
|
|
}
|
2016-05-28 19:34:23 +02:00
|
|
|
|
2016-06-04 20:33:44 +02:00
|
|
|
// the application will shut down, and remove the service named pipe
|
2016-06-06 02:25:28 +02:00
|
|
|
if (srv_close (&srv))
|
2016-06-07 13:49:23 +02:00
|
|
|
ohshit (1, "service_close error");
|
2016-05-28 19:34:23 +02:00
|
|
|
|
2016-06-04 20:33:44 +02:00
|
|
|
return EXIT_SUCCESS;
|
2016-05-28 19:34:23 +02:00
|
|
|
}
|
|
|
|
|
2016-06-06 02:25:28 +02:00
|
|
|
#if 0
|
2016-06-05 20:48:13 +02:00
|
|
|
void main_loop (const struct service *srv)
|
2016-06-04 20:33:44 +02:00
|
|
|
{
|
|
|
|
int ret;
|
|
|
|
struct process proc;
|
|
|
|
|
|
|
|
int cnt = 10;
|
|
|
|
|
|
|
|
while (cnt--) {
|
|
|
|
// -1 : error, 0 = no new process, 1 = new process
|
2016-06-05 20:48:13 +02:00
|
|
|
ret = srv_get_new_process (&proc, srv);
|
2016-06-04 20:33:44 +02:00
|
|
|
if (ret == -1) {
|
|
|
|
fprintf (stderr, "error service_get_new_process\n");
|
|
|
|
continue;
|
|
|
|
} else if (ret == 0) { // that should not happen
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
|
|
|
|
// printf ("before print\n");
|
|
|
|
process_print (&proc);
|
|
|
|
// printf ("after print\n");
|
|
|
|
|
|
|
|
// about the message
|
|
|
|
size_t msize = BUFSIZ;
|
|
|
|
char buf[BUFSIZ];
|
|
|
|
bzero(buf, BUFSIZ);
|
|
|
|
|
|
|
|
// printf ("before read\n");
|
2016-06-05 12:45:45 +02:00
|
|
|
if ((ret = srv_read (&proc, &buf, &msize))) {
|
2016-06-04 20:33:44 +02:00
|
|
|
fprintf(stdout, "error service_read %d\n", ret);
|
|
|
|
continue;
|
|
|
|
}
|
|
|
|
// printf ("after read\n");
|
|
|
|
printf ("read, size %ld : %s\n", msize, buf);
|
|
|
|
|
|
|
|
// printf ("before proc write\n");
|
2016-06-05 12:45:45 +02:00
|
|
|
if ((ret = srv_write (&proc, &buf, msize))) {
|
2016-06-04 20:33:44 +02:00
|
|
|
fprintf(stdout, "error service_write %d\n", ret);
|
|
|
|
continue;
|
|
|
|
}
|
2016-06-05 12:45:45 +02:00
|
|
|
|
2016-06-04 20:33:44 +02:00
|
|
|
// printf ("after proc write\n");
|
|
|
|
printf ("\033[32mStill \033[31m%d\033[32m applications to serve\n",cnt);
|
|
|
|
}
|
|
|
|
}
|
2016-06-06 02:25:28 +02:00
|
|
|
#endif
|