From d5dd2ec98167c5c5b00a14edc471d5f7e2a312a4 Mon Sep 17 00:00:00 2001 From: Andrew Stitcher Date: Fri, 9 Oct 2009 03:38:15 +0000 Subject: Added in passive socket address to SocketAddress and use in Socket::listen() git-svn-id: https://svn.apache.org/repos/asf/qpid/trunk/qpid@823391 13f79535-47bb-0310-9956-ffa450edef68 --- cpp/src/qpid/sys/posix/SocketAddress.cpp | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) (limited to 'cpp/src/qpid/sys/posix/SocketAddress.cpp') diff --git a/cpp/src/qpid/sys/posix/SocketAddress.cpp b/cpp/src/qpid/sys/posix/SocketAddress.cpp index 79008d3944..fe8812299c 100644 --- a/cpp/src/qpid/sys/posix/SocketAddress.cpp +++ b/cpp/src/qpid/sys/posix/SocketAddress.cpp @@ -39,7 +39,16 @@ SocketAddress::SocketAddress(const std::string& host0, const std::string& port0) ::memset(&hints, 0, sizeof(hints)); hints.ai_family = AF_INET; // In order to allow AF_INET6 we'd have to change createTcp() as well hints.ai_socktype = SOCK_STREAM; - int n = ::getaddrinfo(host.c_str(), port.c_str(), &hints, &addrInfo); + + const char* node = 0; + if (host.empty()) { + hints.ai_flags |= AI_PASSIVE; + } else { + node = host.c_str(); + } + const char* service = port.empty() ? "0" : port.c_str(); + + int n = ::getaddrinfo(node, service, &hints, &addrInfo); if (n != 0) throw Exception(QPID_MSG("Cannot resolve " << host << ": " << ::gai_strerror(n))); } -- cgit v1.2.1