wangzhengquan
2020-09-10 591aacee97f4a6486631c38a6b418e20b2c4109c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
 
#include <nanomsg/nn.h>
#include <nanomsg/bus.h>
 
void
fatal(const char *func)
{
  fprintf(stderr, "%s: %s\n", func, nn_strerror(nn_errno()));
  exit(1);
}
 
int
node(const int argc, const char **argv)
{
  int sock;
 
  if ((sock = nn_socket (AF_SP, NN_BUS)) < 0)
  {
    fatal("nn_socket");
  }
  if (nn_bind(sock, argv[2]) < 0)
  {
    fatal("nn_bind");
  }
 
  sleep(1); // wait for peers to bind
  if (argc >= 3)
  {
    for (int x = 3; x < argc; x++)
    {
      if (nn_connect(sock, argv[x]) < 0)
      {
        fatal("nn_connect");
      }
    }
  }
  sleep(1); // wait for connections
  int to = 100;
  if (nn_setsockopt(sock, NN_SOL_SOCKET, NN_RCVTIMEO, &to,
                    sizeof (to)) < 0)
  {
    fatal("nn_setsockopt");
  }
 
  // SEND
  int sz_n = strlen(argv[1]) + 1; // '\0' too
  printf("%s: SENDING '%s' ONTO BUS\n", argv[1], argv[1]);
  if (nn_send(sock, argv[1], sz_n, 0) < 0)
  {
    fatal("nn_send");
  }
 
  // RECV
  for (;;)
  {
    char *buf = NULL;
    int recv = nn_recv(sock, &buf, NN_MSG, 0);
    if (recv >= 0)
    {
      printf("%s: RECEIVED '%s' FROM BUS\n", argv[1], buf);
      nn_freemsg(buf);
    }
  }
  return (nn_shutdown(sock, 0));
}
 
int
main(int argc, const char **argv)
{
  if (argc >= 3)
  {
    return (node(argc, argv));
  }
  fprintf(stderr, "Usage: bus <NODE_NAME> <URL> <URL> ...\n");
  return 1;
}