Updated .travis.yml
This commit is contained in:
parent
ced00adf79
commit
47e4a3a17d
2 changed files with 6 additions and 117 deletions
4
main.c
4
main.c
|
@ -124,9 +124,9 @@ int main(void) {
|
||||||
|
|
||||||
char *command = (char *) malloc(64);
|
char *command = (char *) malloc(64);
|
||||||
sprintf(command, "start http://127.0.0.1:%d/", tcp_getSockPort(webIo.socket));
|
sprintf(command, "start http://127.0.0.1:%d/", tcp_getSockPort(webIo.socket));
|
||||||
//system(command);
|
system(command);
|
||||||
free(command);
|
free(command);
|
||||||
|
|
||||||
logger_log("Starting main loop...");
|
logger_log("Starting main loop...");
|
||||||
bool run = true;
|
bool run = true;
|
||||||
while (run) {
|
while (run) {
|
||||||
|
|
119
test.c
119
test.c
|
@ -25,120 +25,9 @@
|
||||||
|
|
||||||
int main(int argc , char **argv)
|
int main(int argc , char **argv)
|
||||||
{
|
{
|
||||||
int i, maxi, maxfd, listenfd, connfd, sockfd;
|
char buf[10] = "lma";
|
||||||
|
char buf2[10] = "lma";
|
||||||
|
|
||||||
int nready , client[FD_SETSIZE];
|
sprintf(buf,"%c%s",'a',buf2);
|
||||||
|
printf("%s",buf);
|
||||||
ssize_t n, ret;
|
|
||||||
|
|
||||||
fd_set rset , allset;
|
|
||||||
|
|
||||||
char buf[MAX_LINE];
|
|
||||||
|
|
||||||
socklen_t clilen;
|
|
||||||
|
|
||||||
struct sockaddr_in servaddr , cliaddr;
|
|
||||||
|
|
||||||
/*(1) 得到监听描述符*/
|
|
||||||
listenfd = socket(AF_INET , SOCK_STREAM , 0);
|
|
||||||
|
|
||||||
/*(2) 绑定套接字*/
|
|
||||||
bzero(&servaddr , sizeof(servaddr));
|
|
||||||
servaddr.sin_family = AF_INET;
|
|
||||||
servaddr.sin_addr.s_addr = htonl(INADDR_ANY);
|
|
||||||
servaddr.sin_port = htons(PORT);
|
|
||||||
|
|
||||||
bind(listenfd , (struct sockaddr *)&servaddr , sizeof(servaddr));
|
|
||||||
|
|
||||||
/*(3) 监听*/
|
|
||||||
listen(listenfd , LISTENQ);
|
|
||||||
|
|
||||||
/*(4) 设置select*/
|
|
||||||
maxfd = listenfd;
|
|
||||||
maxi = -1;
|
|
||||||
for(i=0 ; i<FD_SETSIZE ; ++i)
|
|
||||||
{
|
|
||||||
client[i] = -1;
|
|
||||||
}//for
|
|
||||||
FD_ZERO(&allset);
|
|
||||||
FD_SET(listenfd , &allset);
|
|
||||||
|
|
||||||
/*(5) 进入服务器接收请求死循环*/
|
|
||||||
while(1)
|
|
||||||
{
|
|
||||||
rset = allset;
|
|
||||||
nready = select(maxfd+1 , &rset , NULL , NULL , NULL);
|
|
||||||
|
|
||||||
if(FD_ISSET(listenfd , &rset))
|
|
||||||
{
|
|
||||||
/*接收客户端的请求*/
|
|
||||||
clilen = sizeof(cliaddr);
|
|
||||||
|
|
||||||
printf("\naccpet connection~\n");
|
|
||||||
|
|
||||||
if((connfd = accept(listenfd , (struct sockaddr *)&cliaddr , &clilen)) < 0)
|
|
||||||
{
|
|
||||||
perror("accept error.\n");
|
|
||||||
exit(1);
|
|
||||||
}//if
|
|
||||||
char buf[4096];
|
|
||||||
read(connfd,buf,4096);
|
|
||||||
printf("%s",buf);
|
|
||||||
printf("accpet a new client: %s:%d\n", inet_ntoa(cliaddr.sin_addr) , cliaddr.sin_port);
|
|
||||||
|
|
||||||
/*将客户链接套接字描述符添加到数组*/
|
|
||||||
for(i=0 ; i<FD_SETSIZE ; ++i)
|
|
||||||
{
|
|
||||||
if(client[i] < 0)
|
|
||||||
{
|
|
||||||
client[i] = connfd;
|
|
||||||
break;
|
|
||||||
}//if
|
|
||||||
}//for
|
|
||||||
|
|
||||||
if(FD_SETSIZE == i)
|
|
||||||
{
|
|
||||||
perror("too many connection.\n");
|
|
||||||
exit(1);
|
|
||||||
}//if
|
|
||||||
|
|
||||||
FD_SET(connfd , &allset);
|
|
||||||
if(connfd > maxfd)
|
|
||||||
maxfd = connfd;
|
|
||||||
if(i > maxi)
|
|
||||||
maxi = i;
|
|
||||||
|
|
||||||
if(--nready < 0)
|
|
||||||
continue;
|
|
||||||
}//if
|
|
||||||
|
|
||||||
for(i=0; i<=maxi ; ++i)
|
|
||||||
{
|
|
||||||
if((sockfd = client[i]) < 0)
|
|
||||||
continue;
|
|
||||||
if(FD_ISSET(sockfd , &rset))
|
|
||||||
{
|
|
||||||
/*处理客户请求*/
|
|
||||||
printf("\nreading the socket~~~ \n");
|
|
||||||
|
|
||||||
bzero(buf , MAX_LINE);
|
|
||||||
if((n = read(sockfd , buf , MAX_LINE)) <= 0)
|
|
||||||
{
|
|
||||||
close(sockfd);
|
|
||||||
FD_CLR(sockfd , &allset);
|
|
||||||
client[i] = -1;
|
|
||||||
}//if
|
|
||||||
else{
|
|
||||||
printf("clint[%d] send message: %s\n", i , buf);
|
|
||||||
if((ret = write(sockfd , buf , n)) != n)
|
|
||||||
{
|
|
||||||
printf("error writing to the sockfd!\n");
|
|
||||||
break;
|
|
||||||
}//if
|
|
||||||
}//else
|
|
||||||
if(--nready <= 0)
|
|
||||||
break;
|
|
||||||
}//if
|
|
||||||
}//for
|
|
||||||
}//while
|
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue