dgclibcast6.c 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364
  1. #include "unp.h"
  2. static void recvfrom_alarm(int);
  3. static int pipefd[2];
  4. void
  5. dg_cli(FILE *fp, int sockfd, const SA *pservaddr, socklen_t servlen)
  6. {
  7. int n, maxfdp1;
  8. const int on = 1;
  9. char sendline[MAXLINE], recvline[MAXLINE + 1];
  10. fd_set rset;
  11. socklen_t len;
  12. struct sockaddr *preply_addr;
  13. preply_addr = Malloc(servlen);
  14. Setsockopt(sockfd, SOL_SOCKET, SO_BROADCAST, &on, sizeof(on));
  15. Pipe(pipefd);
  16. maxfdp1 = max(sockfd, pipefd[0]) + 1;
  17. FD_ZERO(&rset);
  18. Signal(SIGALRM, recvfrom_alarm);
  19. while (Fgets(sendline, MAXLINE, fp) != NULL) {
  20. Sendto(sockfd, sendline, strlen(sendline), 0, pservaddr, servlen);
  21. alarm(5);
  22. for ( ; ; ) {
  23. FD_SET(sockfd, &rset);
  24. FD_SET(pipefd[0], &rset);
  25. if ( (n = select(maxfdp1, &rset, NULL, NULL, NULL)) < 0) {
  26. if (errno == EINTR)
  27. continue;
  28. else
  29. err_sys("select error");
  30. }
  31. if (FD_ISSET(sockfd, &rset)) {
  32. len = servlen;
  33. n = Recvfrom(sockfd, recvline, MAXLINE, 0, preply_addr, &len);
  34. recvline[n] = 0; /* null terminate */
  35. printf("from %s: %s",
  36. Sock_ntop_host(preply_addr, len), recvline);
  37. }
  38. if (FD_ISSET(pipefd[0], &rset)) {
  39. Read(pipefd[0], &n, 1); /* timer expired */
  40. break;
  41. }
  42. }
  43. }
  44. free(preply_addr);
  45. }
  46. static void
  47. recvfrom_alarm(int signo)
  48. {
  49. Write(pipefd[1], "", 1); /* write one null byte to pipe */
  50. return;
  51. }