diff options
author | levine <levine@ae88bc3d-4319-0410-8dbf-d08b4c9d3795> | 1997-12-12 19:29:06 +0000 |
---|---|---|
committer | levine <levine@ae88bc3d-4319-0410-8dbf-d08b4c9d3795> | 1997-12-12 19:29:06 +0000 |
commit | 925d4918a6f6023693d3a87227d1bbc337a1f77e (patch) | |
tree | d4e7bb3bf1c8cf4442bb13bd58b66a25b17a6937 /examples/IPC_SAP/SOCK_SAP/C-inserver.cpp | |
parent | 224dac116e75a7813d013d7e730a732983e5f2e7 (diff) | |
download | ATCD-925d4918a6f6023693d3a87227d1bbc337a1f77e.tar.gz |
added support to optionally set socket buffers sizes
Diffstat (limited to 'examples/IPC_SAP/SOCK_SAP/C-inserver.cpp')
-rw-r--r-- | examples/IPC_SAP/SOCK_SAP/C-inserver.cpp | 54 |
1 files changed, 34 insertions, 20 deletions
diff --git a/examples/IPC_SAP/SOCK_SAP/C-inserver.cpp b/examples/IPC_SAP/SOCK_SAP/C-inserver.cpp index 1bbcb64d4d8..c9aea99ae78 100644 --- a/examples/IPC_SAP/SOCK_SAP/C-inserver.cpp +++ b/examples/IPC_SAP/SOCK_SAP/C-inserver.cpp @@ -1,6 +1,6 @@ -#include "ace/OS.h" // $Id$ +#include "ace/OS.h" /* BSD socket server. */ @@ -9,15 +9,29 @@ int main (int argc, char *argv[]) // Initialize WinSock DLL on Win32... ACE_OS::socket_init (ACE_WSOCK_VERSION); - u_short port_num = + u_short port_num = htons (argc > 1 ? ACE_OS::atoi (argv[1]) : ACE_DEFAULT_SERVER_PORT); + int sockbufsize = argc > 2 ? ACE_OS::atoi (argv[2]) : 0; struct sockaddr_in saddr; - ACE_HANDLE s_handle, n_handle; + ACE_HANDLE s_handle, n_handle; /* Create a local endpoint of communication */ if ((s_handle = ACE_OS::socket (PF_INET, SOCK_STREAM, 0)) == ACE_INVALID_HANDLE) ACE_OS::perror ("socket"), ACE_OS::exit (1); + // If a sockbufsize was specified, set it for both send and receive. + if (sockbufsize > 0) + { + if (ACE_OS::setsockopt (s_handle, SOL_SOCKET, SO_SNDBUF, + (const char *) &sockbufsize, + sizeof (sockbufsize)) != 0) + ACE_OS::perror ("SO_SNDBUF"), ACE_OS::exit (1); + if (ACE_OS::setsockopt (s_handle, SOL_SOCKET, SO_RCVBUF, + (const char *) &sockbufsize, + sizeof (sockbufsize)) != 0) + ACE_OS::perror ("SO_RCVBUF"), ACE_OS::exit (1); + } + /* Set up the address information to become a server */ ACE_OS::memset ((void *) &saddr, 0, sizeof saddr); saddr.sin_family = AF_INET; @@ -25,17 +39,17 @@ int main (int argc, char *argv[]) saddr.sin_addr.s_addr = INADDR_ANY; /* Associate address with endpoint */ - if (ACE_OS::bind (s_handle, (struct sockaddr *) &saddr, - sizeof saddr) == -1) + if (ACE_OS::bind (s_handle, (struct sockaddr *) &saddr, + sizeof saddr) == -1) ACE_OS::perror ("bind"), ACE_OS::exit (1); /* Make endpoint listen for service requests */ - if (ACE_OS::listen (s_handle, 5) == -1) + if (ACE_OS::listen (s_handle, 5) == -1) ACE_OS::perror ("listen"), ACE_OS::exit (1); /* Performs the iterative server activities */ - for (;;) + for (;;) { char buf[BUFSIZ]; int r_bytes; @@ -44,38 +58,38 @@ int main (int argc, char *argv[]) struct hostent *hp; /* Create a new endpoint of communication */ - do - n_handle = ACE_OS::accept (s_handle, (struct sockaddr *) + do + n_handle = ACE_OS::accept (s_handle, (struct sockaddr *) &cli_addr, &cli_addr_len); while (n_handle == ACE_INVALID_HANDLE && errno == EINTR); - - if (n_handle == ACE_INVALID_HANDLE) - { - ACE_OS::perror ("accept"); - continue; - } + + if (n_handle == ACE_INVALID_HANDLE) + { + ACE_OS::perror ("accept"); + continue; + } int addr_len = sizeof cli_addr.sin_addr.s_addr; hp = ACE_OS::gethostbyaddr ((char *) &cli_addr.sin_addr, addr_len, AF_INET); - if (hp != 0) + if (hp != 0) ACE_OS::printf ("client %s\n", hp->h_name), ACE_OS::fflush (stdout); else ACE_OS::perror ("gethostbyaddr"); /* Read data from client (terminate on error) */ - + while ((r_bytes = ACE_OS::recv (n_handle, buf, sizeof buf)) > 0) if (ACE_OS::write (ACE_STDOUT, buf, r_bytes) != r_bytes) ACE_OS::perror ("write"), ACE_OS::exit (1); if (ACE_OS::send (n_handle, "", 1) != 1) - ::perror ("write"), ACE_OS::exit (1); + ::perror ("write"), ACE_OS::exit (1); - /* Close the new endpoint + /* Close the new endpoint (listening endpoint remains open) */ - if (ACE_OS::closesocket (n_handle) == -1) + if (ACE_OS::closesocket (n_handle) == -1) ACE_OS::perror ("close"), ACE_OS::exit (1); ACE_OS::exit (0); } |