server.cpp 2.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566
  1. #include "hloop.h"
  2. #define RECV_BUFSIZE 4096
  3. static char readbuf[RECV_BUFSIZE];
  4. void on_timer(htimer_t* timer) {
  5. static int cnt = 0;
  6. printf("on_timer timer_id=%lu time=%lus cnt=%d\n", timer->event_id, hloop_now(timer->loop), ++cnt);
  7. }
  8. void on_idle(hidle_t* idle) {
  9. static int cnt = 0;
  10. printf("on_idle idle_id=%lu cnt=%d\n", idle->event_id, ++cnt);
  11. }
  12. void on_write(hio_t* io, const void* buf, int writebytes) {
  13. printf("on_write fd=%d writebytes=%d\n", io->fd, writebytes);
  14. }
  15. void on_close(hio_t* io) {
  16. printf("on_close fd=%d error=%d\n", io->fd, io->error);
  17. }
  18. void on_read(hio_t* io, void* buf, int readbytes) {
  19. printf("on_read fd=%d readbytes=%d\n", io->fd, readbytes);
  20. printf("< %s\n", buf);
  21. // echo
  22. printf("> %s\n", buf);
  23. hwrite(io->loop, io->fd, buf, readbytes, on_write);
  24. }
  25. void on_accept(hio_t* io, int connfd) {
  26. printf("on_accept listenfd=%d connfd=%d\n", io->fd, connfd);
  27. struct sockaddr_in* localaddr = (struct sockaddr_in*)io->localaddr;
  28. struct sockaddr_in* peeraddr = (struct sockaddr_in*)io->peeraddr;
  29. char localip[64];
  30. char peerip[64];
  31. inet_ntop(AF_INET, &localaddr->sin_addr, localip, sizeof(localip));
  32. inet_ntop(AF_INET, &peeraddr->sin_addr, peerip, sizeof(peerip));
  33. printf("accept listenfd=%d connfd=%d [%s:%d] <= [%s:%d]\n", io->fd, connfd,
  34. localip, ntohs(localaddr->sin_port),
  35. peerip, ntohs(peeraddr->sin_port));
  36. // one loop can use one readbuf
  37. hio_t* connio = hread(io->loop, connfd, readbuf, RECV_BUFSIZE, on_read);
  38. connio->close_cb = on_close;
  39. }
  40. int main(int argc, char** argv) {
  41. if (argc < 2) {
  42. printf("Usage: cmd port\n");
  43. return -10;
  44. }
  45. int port = atoi(argv[1]);
  46. hloop_t loop;
  47. hloop_init(&loop);
  48. //hidle_add(&loop, on_idle, INFINITE);
  49. //htimer_add(&loop, on_timer, 1000, INFINITE);
  50. hio_t* io = hlisten(&loop, port, on_accept);
  51. if (io == NULL) {
  52. return -20;
  53. }
  54. printf("listenfd=%d\n", io->fd);
  55. hloop_run(&loop);
  56. }