server.cpp 2.0 KB

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