server.cpp 2.2 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374
  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_write(hio_t* io, const void* buf, int writebytes, void* userdata) {
  20. printf("on_write fd=%d writebytes=%d\n", io->fd, writebytes);
  21. }
  22. void on_read(hio_t* io, void* buf, int readbytes) {
  23. printf("on_read fd=%d readbytes=%d\n", io->fd, readbytes);
  24. printf("< %s\n", buf);
  25. // echo
  26. printf("> %s\n", buf);
  27. hwrite(io->loop, io->fd, buf, readbytes, on_write);
  28. }
  29. void on_accept(hio_t* io, int connfd) {
  30. printf("on_accept listenfd=%d connfd=%d\n", io->fd, connfd);
  31. struct sockaddr_in localaddr, peeraddr;
  32. socklen_t addrlen;
  33. addrlen = sizeof(struct sockaddr_in);
  34. getsockname(connfd, (struct sockaddr*)&localaddr, &addrlen);
  35. addrlen = sizeof(struct sockaddr_in);
  36. getpeername(connfd, (struct sockaddr*)&peeraddr, &addrlen);
  37. printf("accept connfd=%d [%s:%d] <= [%s:%d]\n", connfd,
  38. inet_ntoa(localaddr.sin_addr), ntohs(localaddr.sin_port),
  39. inet_ntoa(peeraddr.sin_addr), ntohs(peeraddr.sin_port));
  40. nonblocking(connfd);
  41. // one loop can use one readbuf
  42. hio_t* connio = hread(io->loop, connfd, readbuf, RECV_BUFSIZE, on_read);
  43. connio->close_cb = on_close;
  44. }
  45. int main(int argc, char** argv) {
  46. if (argc < 2) {
  47. printf("Usage: cmd port\n");
  48. return -10;
  49. }
  50. int port = atoi(argv[1]);
  51. int listenfd = Listen(port);
  52. printf("listenfd=%d\n", listenfd);
  53. if (listenfd < 0) {
  54. return listenfd;
  55. }
  56. hloop_t loop;
  57. hloop_init(&loop);
  58. //hidle_add(&loop, on_idle, INFINITE);
  59. //htimer_add(&loop, on_timer, 1000, INFINITE);
  60. haccept(&loop, listenfd, on_accept);
  61. hloop_run(&loop);
  62. }