diff options
author | maximius <none@none> | 2009-10-17 15:51:44 -0700 |
---|---|---|
committer | maximius <none@none> | 2009-10-17 15:51:44 -0700 |
commit | e585187b248f48b3c6e9247b49fa07c6565d65e5 (patch) | |
tree | 637c5b7ddacf41040bef4ea4f75a97da64c6a9bc /dep/ACE_wrappers/ace/Pipe.cpp | |
parent | 26b5e033ffde3d161382fc9addbfa99738379641 (diff) |
*Backed out changeset 3be01fb200a5
--HG--
branch : trunk
Diffstat (limited to 'dep/ACE_wrappers/ace/Pipe.cpp')
-rw-r--r-- | dep/ACE_wrappers/ace/Pipe.cpp | 49 |
1 files changed, 49 insertions, 0 deletions
diff --git a/dep/ACE_wrappers/ace/Pipe.cpp b/dep/ACE_wrappers/ace/Pipe.cpp index 95075772f0e..717f72e52ea 100644 --- a/dep/ACE_wrappers/ace/Pipe.cpp +++ b/dep/ACE_wrappers/ace/Pipe.cpp @@ -1,4 +1,5 @@ // $Id: Pipe.cpp 80826 2008-03-04 14:51:23Z wotte $ + #include "ace/Pipe.h" #include "ace/SOCK_Acceptor.h" #include "ace/SOCK_Connector.h" @@ -6,15 +7,21 @@ #include "ace/OS_NS_sys_socket.h" #include "ace/OS_Memory.h" #include "ace/Truncate.h" + #if defined (ACE_HAS_STREAM_PIPES) || defined (__QNX__) # include "ace/OS_NS_unistd.h" #endif // ACE_HAS_STREAM_PIPES || __QNX__ + #include "ace/os_include/netinet/os_tcp.h" + #if !defined (__ACE_INLINE__) #include "ace/Pipe.inl" #endif /* __ACE_INLINE__ */ + ACE_RCSID(ace, Pipe, "$Id: Pipe.cpp 80826 2008-03-04 14:51:23Z wotte $") + ACE_BEGIN_VERSIONED_NAMESPACE_DECL + void ACE_Pipe::dump (void) const { @@ -27,10 +34,12 @@ ACE_Pipe::dump (void) const ACE_DEBUG ((LM_DEBUG, ACE_END_DUMP)); #endif /* ACE_HAS_DUMP */ } + int ACE_Pipe::open (int buffer_size) { ACE_TRACE ("ACE_Pipe::open"); + #if defined (ACE_LACKS_SOCKETPAIR) || defined (__Lynx__) ACE_INET_Addr my_addr; ACE_SOCK_Acceptor acceptor; @@ -43,6 +52,7 @@ ACE_Pipe::open (int buffer_size) # else ACE_Addr local_any = ACE_Addr::sap_any; # endif /* ACE_WIN32 */ + // Bind listener to any port and then find out what the port was. if (acceptor.open (local_any) == -1 || acceptor.get_local_addr (my_addr) == -1) @@ -51,6 +61,7 @@ ACE_Pipe::open (int buffer_size) { ACE_INET_Addr sv_addr (my_addr.get_port_number (), ACE_LOCALHOST); + // Establish a connection within the same process. if (connector.connect (writer, sv_addr) == -1) result = -1; @@ -60,17 +71,22 @@ ACE_Pipe::open (int buffer_size) result = -1; } } + // Close down the acceptor endpoint since we don't need it anymore. acceptor.close (); if (result == -1) return -1; + this->handles_[0] = reader.get_handle (); this->handles_[1] = writer.get_handle (); + # if !defined (ACE_LACKS_TCP_NODELAY) int one = 1; + // Make sure that the TCP stack doesn't try to buffer small writes. // Since this communication is purely local to the host it doesn't // affect network performance. + if (writer.set_option (ACE_IPPROTO_TCP, TCP_NODELAY, &one, @@ -80,6 +96,7 @@ ACE_Pipe::open (int buffer_size) return -1; } # endif /* ! ACE_LACKS_TCP_NODELAY */ + # if defined (ACE_LACKS_SOCKET_BUFSIZ) ACE_UNUSED_ARG (buffer_size); # else /* ! ACE_LACKS_SOCKET_BUFSIZ */ @@ -102,6 +119,7 @@ ACE_Pipe::open (int buffer_size) return -1; } # endif /* ! ACE_LACKS_SOCKET_BUFSIZ */ + #elif defined (ACE_HAS_STREAM_PIPES) || defined (__QNX__) ACE_UNUSED_ARG (buffer_size); if (ACE_OS::pipe (this->handles_) == -1) @@ -109,8 +127,10 @@ ACE_Pipe::open (int buffer_size) ACE_TEXT ("%p\n"), ACE_TEXT ("pipe")), -1); + #if !defined(__QNX__) int arg = RMSGN; + // Enable "msg no discard" mode, which ensures that record // boundaries are maintained when messages are sent and received. if (ACE_OS::ioctl (this->handles_[0], @@ -126,6 +146,7 @@ ACE_Pipe::open (int buffer_size) ACE_TEXT ("ioctl")), -1); } #endif /* __QNX__ */ + #else /* ! ACE_LACKS_SOCKETPAIR && ! ACE_HAS_STREAM_PIPES */ if (ACE_OS::socketpair (AF_UNIX, SOCK_STREAM, @@ -177,12 +198,15 @@ ACE_Pipe::open (int buffer_size) #endif /* ! ACE_LACKS_SOCKETPAIR && ! ACE_HAS_STREAM_PIPES */ // Point both the read and write HANDLES to the appropriate socket // HANDLEs. + return 0; } + int ACE_Pipe::open (ACE_HANDLE handles[2]) { ACE_TRACE ("ACE_Pipe::open"); + if (this->open () == -1) return -1; else @@ -192,20 +216,26 @@ ACE_Pipe::open (ACE_HANDLE handles[2]) return 0; } } + // Do nothing... + ACE_Pipe::ACE_Pipe (void) { ACE_TRACE ("ACE_Pipe::ACE_Pipe"); + this->handles_[0] = ACE_INVALID_HANDLE; this->handles_[1] = ACE_INVALID_HANDLE; } + ACE_Pipe::ACE_Pipe (ACE_HANDLE handles[2]) { ACE_TRACE ("ACE_Pipe::ACE_Pipe"); + if (this->open (handles) == -1) ACE_ERROR ((LM_ERROR, ACE_TEXT ("ACE_Pipe::ACE_Pipe"))); } + ACE_Pipe::ACE_Pipe (ACE_HANDLE read, ACE_HANDLE write) { @@ -213,26 +243,34 @@ ACE_Pipe::ACE_Pipe (ACE_HANDLE read, this->handles_[0] = read; this->handles_[1] = write; } + int ACE_Pipe::close (void) { ACE_TRACE ("ACE_Pipe::close"); + int result = 0; + // Note that the following will work even if we aren't closing down // sockets because <ACE_OS::closesocket> will just call <::close> in // that case! + if (this->handles_[0] != ACE_INVALID_HANDLE) result = ACE_OS::closesocket (this->handles_[0]); this->handles_[0] = ACE_INVALID_HANDLE; + if (this->handles_[1] != ACE_INVALID_HANDLE) result |= ACE_OS::closesocket (this->handles_[1]); this->handles_[1] = ACE_INVALID_HANDLE; + return result; } + // Send N char *ptrs and int lengths. Note that the char *'s precede // the ints (basically, an varargs version of writev). The count N is // the *total* number of trailing arguments, *not* a couple of the // number of tuple pairs! + ssize_t ACE_Pipe::send (size_t n, ...) const { @@ -247,12 +285,15 @@ ACE_Pipe::send (size_t n, ...) const iovec[total_tuples], -1); #endif /* !defined (ACE_HAS_ALLOCA) */ + va_start (argp, n); + for (int i = 0; i < total_tuples; ++i) { iovp[i].iov_base = va_arg (argp, char *); iovp[i].iov_len = va_arg (argp, int); } + #if defined (ACE_WIN32) ssize_t result = ACE::sendv (this->write_handle (), iovp, @@ -262,17 +303,20 @@ ACE_Pipe::send (size_t n, ...) const iovp, total_tuples); #endif /* ACE_WIN32 */ + #if !defined (ACE_HAS_ALLOCA) delete [] iovp; #endif /* !defined (ACE_HAS_ALLOCA) */ va_end (argp); return result; } + // This is basically an interface to ACE_OS::readv, that doesn't use // the struct iovec explicitly. The ... can be passed as an arbitrary // number of (char *ptr, int len) tuples. However, the count N is the // *total* number of trailing arguments, *not* a couple of the number // of tuple pairs! + ssize_t ACE_Pipe::recv (size_t n, ...) const { @@ -287,12 +331,15 @@ ACE_Pipe::recv (size_t n, ...) const iovec[total_tuples], -1); #endif /* !defined (ACE_HAS_ALLOCA) */ + va_start (argp, n); + for (int i = 0; i < total_tuples; ++i) { iovp[i].iov_base = va_arg (argp, char *); iovp[i].iov_len = va_arg (argp, int); } + #if defined (ACE_WIN32) ssize_t const result = ACE::recvv (this->read_handle (), iovp, @@ -302,11 +349,13 @@ ACE_Pipe::recv (size_t n, ...) const iovp, total_tuples); #endif /* ACE_WIN32 */ + #if !defined (ACE_HAS_ALLOCA) delete [] iovp; #endif /* !defined (ACE_HAS_ALLOCA) */ va_end (argp); return result; } + ACE_END_VERSIONED_NAMESPACE_DECL |