diff options
Diffstat (limited to 'examples/IPC_SAP/ATM_SAP/CPP-server.cpp')
-rw-r--r-- | examples/IPC_SAP/ATM_SAP/CPP-server.cpp | 156 |
1 files changed, 0 insertions, 156 deletions
diff --git a/examples/IPC_SAP/ATM_SAP/CPP-server.cpp b/examples/IPC_SAP/ATM_SAP/CPP-server.cpp deleted file mode 100644 index 8cf6e9c9c92..00000000000 --- a/examples/IPC_SAP/ATM_SAP/CPP-server.cpp +++ /dev/null @@ -1,156 +0,0 @@ -// $Id$ - -#include "ace/OS_main.h" -#include "ace/ATM_Acceptor.h" -#include "ace/ATM_Addr.h" -#include "ace/High_Res_Timer.h" -#include "ace/Log_Msg.h" - -ACE_RCSID(ATM_SAP, CPP_ATM_server, "$Id$") - -#if defined (ACE_HAS_ATM) -// ACE_ATM Server - -int -ACE_TMAIN (int argc, ACE_TCHAR *argv[]) -{ - ACE_Time_Value timeout (ACE_DEFAULT_TIMEOUT); - - //unsigned char selector = ACE_ATM_Addr::DEFAULT_SELECTOR; - //int selector_specified = 0; - - if (argc > 2) - ACE_ERROR_RETURN ((LM_ERROR, - "Usage: %s [selector]\n", - argv[0]), - 1); - - // Create a server address. - ACE_ATM_Addr addr; - //if (selector_specified) - unsigned char selector = ( argc == 2 ) ? ACE_OS::atoi( argv[ 1 ]) : ACE_ATM_Addr::DEFAULT_SELECTOR; - addr.set_selector( selector ); - ACE_OS::printf( "ATM_Server: selector changed to %d\n", addr.get_selector()); - - - // Create a server, reuse the addr. - ACE_ATM_Acceptor peer_acceptor; - ACE_ATM_Params params; - - // Not sure why but reuse_addr set to true/1 causes problems for - // FORE/XTI/ATM - this is now handled in ACE_ATM_Acceptor::open() - - ACE_HANDLE ret = peer_acceptor.open (addr, 5, params); - if ( ret == ACE_INVALID_HANDLE ) - ACE_ERROR_RETURN ((LM_ERROR, - "%p\n", - "open"), - -1); - - ACE_ATM_Stream new_stream; - ACE_ATM_Addr local_addr; - - local_addr.set_selector( selector ); - peer_acceptor.get_local_addr( local_addr ); - - ACE_DEBUG ((LM_DEBUG, - "starting server at address %s\n", - local_addr.addr_to_string ())); - - // Performs the iterative server activities - char buf[BUFSIZ]; - ACE_High_Res_Timer timer; - int total; - ACE_Time_Value tv; - double real_time; - double actual_rate; - - for (;;) { - // Create a new ACE_ATM_Stream endpoint (note automatic restart - // if errno == EINTR). - ACE_OS::printf( "ATM_Server: expecting clients\n" ); - - if (peer_acceptor.accept (new_stream, - &addr, - &timeout) == -1) { - ACE_ERROR ((LM_ERROR, - "%p\n", - "accept")); - continue; - } - - ACE_OS::printf( "ATM_Server: got a connection\n" ); - - ACE_UINT16 vpi, vci; - vpi = vci = 0; - // This has problem on PMP connections on NT - //new_stream.get_vpi_vci(vpi, vci); - ACE_DEBUG ((LM_DEBUG, - "connected to VPI %d VCI %d\n", - vpi, vci)); - - ACE_OS::printf( "ATM_Server: connection accepted\n" ); - - ACE_DEBUG ((LM_DEBUG, - "client %s connected\n", - addr.addr_to_string ())); - ACE_DEBUG ((LM_DEBUG, - "client %s connected to host\n", - new_stream.get_peer_name ())); - - // Read data from client (terminate on error). - - int recvd = 0; - - for ( ;; ) { - total = 0; - timer.start_incr(); - - for (int r_bytes; - (r_bytes = new_stream.recv (buf, sizeof buf, 0)) > 0; ) { -// ACE_OS::printf( "ATM_Server: received %dB\n", r_bytes ); - -// if (ACE_OS::write (ACE_STDOUT, -// buf, -// r_bytes) != r_bytes) -// ACE_ERROR ((LM_ERROR, -// "%p\n", -// "ACE::send_n")); - total += r_bytes; - - if ( total > 10000000 ) - break; - - } - - timer.stop_incr(); - timer.elapsed_time_incr( tv ); - real_time = tv.sec() * ACE_ONE_SECOND_IN_USECS + tv.usec(); - recvd += total; - actual_rate = ( double )recvd * ( double )8 / real_time; - - ACE_DEBUG ((LM_DEBUG, - ACE_TEXT ("(%t) bytes = %d, usec = %f, rate = %0.00f Mbps\n"), - recvd, - real_time, - actual_rate < 0 ? 0 : actual_rate )); - } - - // Close new endpoint (listening endpoint stays open). - if (new_stream.close () == -1) - ACE_ERROR ((LM_ERROR, - "%p\n", - "close")); - } - - /* NOTREACHED */ - return 0; -} -#else -int ACE_TMAIN (int, ACE_TCHAR *[]) -{ - ACE_ERROR_RETURN ((LM_ERROR, - "your platform isn't configured to support ATM\n"), - 1); -} -#endif /* ACE_HAS_ATM */ |