| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566 |
- #include "hloop.h"
- #define RECV_BUFSIZE 4096
- static char readbuf[RECV_BUFSIZE];
- void on_timer(htimer_t* timer) {
- static int cnt = 0;
- printf("on_timer timer_id=%lu time=%lus cnt=%d\n", timer->event_id, hloop_now(timer->loop), ++cnt);
- }
- void on_idle(hidle_t* idle) {
- static int cnt = 0;
- printf("on_idle idle_id=%lu cnt=%d\n", idle->event_id, ++cnt);
- }
- void on_write(hio_t* io, const void* buf, int writebytes) {
- printf("on_write fd=%d writebytes=%d\n", io->fd, writebytes);
- }
- void on_close(hio_t* io) {
- printf("on_close fd=%d error=%d\n", io->fd, io->error);
- }
- void on_read(hio_t* io, void* buf, int readbytes) {
- printf("on_read fd=%d readbytes=%d\n", io->fd, readbytes);
- printf("< %s\n", buf);
- // echo
- printf("> %s\n", buf);
- hwrite(io->loop, io->fd, buf, readbytes, on_write);
- }
- void on_accept(hio_t* io, int connfd) {
- printf("on_accept listenfd=%d connfd=%d\n", io->fd, connfd);
- struct sockaddr_in* localaddr = (struct sockaddr_in*)io->localaddr;
- struct sockaddr_in* peeraddr = (struct sockaddr_in*)io->peeraddr;
- char localip[64];
- char peerip[64];
- inet_ntop(AF_INET, &localaddr->sin_addr, localip, sizeof(localip));
- inet_ntop(AF_INET, &peeraddr->sin_addr, peerip, sizeof(peerip));
- printf("accept listenfd=%d connfd=%d [%s:%d] <= [%s:%d]\n", io->fd, connfd,
- localip, ntohs(localaddr->sin_port),
- peerip, ntohs(peeraddr->sin_port));
- // one loop can use one readbuf
- hio_t* connio = hread(io->loop, connfd, readbuf, RECV_BUFSIZE, on_read);
- connio->close_cb = on_close;
- }
- int main(int argc, char** argv) {
- if (argc < 2) {
- printf("Usage: cmd port\n");
- return -10;
- }
- int port = atoi(argv[1]);
- hloop_t loop;
- hloop_init(&loop);
- //hidle_add(&loop, on_idle, INFINITE);
- //htimer_add(&loop, on_timer, 1000, INFINITE);
- hio_t* io = hlisten(&loop, port, on_accept);
- if (io == NULL) {
- return -20;
- }
- printf("listenfd=%d\n", io->fd);
- hloop_run(&loop);
- }
|