/[LeafOK_CVS]/lbbs/src/net_server.c
ViewVC logotype

Diff of /lbbs/src/net_server.c

Parent Directory Parent Directory | Revision Log Revision Log | View Patch Patch

Revision 1.9 by sysadm, Sat Mar 19 14:44:21 2005 UTC Revision 1.10 by sysadm, Sun Mar 20 17:37:14 2005 UTC
# Line 41  net_server (const char *hostaddr, unsign Line 41  net_server (const char *hostaddr, unsign
41      (strlen (hostaddr) > 0 ? inet_addr (hostaddr) : INADDR_ANY);      (strlen (hostaddr) > 0 ? inet_addr (hostaddr) : INADDR_ANY);
42    sin.sin_port = htons (port);    sin.sin_port = htons (port);
43    
44    if (bind (socket_server, (struct sockaddr *)&sin, sizeof(sin)) < 0)    if (bind (socket_server, (struct sockaddr *) &sin, sizeof (sin)) < 0)
45      {      {
46        log_error ("Bind address %s:%u failed\n",        log_error ("Bind address %s:%u failed\n",
47          inet_ntoa(sin.sin_addr), ntohs(sin.sin_port));                   inet_ntoa (sin.sin_addr), ntohs (sin.sin_port));
48        exit (2);        exit (2);
49      }      }
50    
# Line 54  net_server (const char *hostaddr, unsign Line 54  net_server (const char *hostaddr, unsign
54        exit (3);        exit (3);
55      }      }
56    
57    strcpy(hostaddr_server, inet_ntoa(sin.sin_addr));    strcpy (hostaddr_server, inet_ntoa (sin.sin_addr));
58    port_server = ntohs(sin.sin_port);    port_server = ntohs (sin.sin_port);
59      
60    log_std ("Listening at %s:%d\n", hostaddr_server, port_server);    log_std ("Listening at %s:%d\n", hostaddr_server, port_server);
61    
62    namelen = sizeof (sin);    namelen = sizeof (sin);
63    while(1)    while (1)
64      {      {
65        if ((socket_client = accept (socket_server, (struct sockaddr *) &sin, &namelen)) < 0)        if ((socket_client =
66          {             accept (socket_server, (struct sockaddr *) &sin, &namelen)) < 0)
67            log_error ("Accept connection error\n");          {
68            continue;            log_error ("Accept connection error\n");
69          }            continue;
70            }
71        strcpy (hostaddr_client, (const char *)inet_ntoa(sin.sin_addr));  
72        port_client = ntohs(sin.sin_port);        strcpy (hostaddr_client, (const char *) inet_ntoa (sin.sin_addr));
73          port_client = ntohs (sin.sin_port);
74        log_std ("Accept connection from %s:%d\n", hostaddr_client, port_client);  
75                log_std ("Accept connection from %s:%d\n", hostaddr_client,
76        if (fork_server()<0)                 port_client);
77          {  
78            log_error ("Fork error\n");        if (fork_server () < 0)
79          }          {
80                    log_error ("Fork error\n");
81        if (close(socket_client) == -1)          }
82          {  
83            log_error("Close client socket failed\n");        if (close (socket_client) == -1)
84          }          {
85              log_error ("Close client socket failed\n");
86            }
87      }      }
88    
89    if (close(socket_server) == -1)    if (close (socket_server) == -1)
90      {      {
91        log_error("Close server socket failed\n");        log_error ("Close server socket failed\n");
92      }      }
93    
94    return 0;    return 0;


Legend:
Removed lines/characters  
Changed lines/characters
  Added lines/characters

webmaster@leafok.com
ViewVC Help
Powered by ViewVC 1.3.0-beta1