summaryrefslogtreecommitdiff
path: root/cpp
diff options
context:
space:
mode:
authorTed Ross <tross@apache.org>2008-11-11 20:15:49 +0000
committerTed Ross <tross@apache.org>2008-11-11 20:15:49 +0000
commit2b9aba3af8c27b22e4fdc3d8ccd3e0aae0c5c6fc (patch)
tree8505794882536d555b388499efa7215ead2dbeed /cpp
parentc52f58558346b5d71af7c0c13f56b3a760b48986 (diff)
downloadqpid-python-2b9aba3af8c27b22e4fdc3d8ccd3e0aae0c5c6fc.tar.gz
Fixed a file-descriptor leak in the c++ client API. If the socket connection
fails, the socket is never closed. git-svn-id: https://svn.apache.org/repos/asf/incubator/qpid/trunk/qpid@713154 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'cpp')
-rw-r--r--cpp/src/qpid/client/Connector.cpp8
-rw-r--r--cpp/src/qpid/client/SslConnector.cpp8
2 files changed, 14 insertions, 2 deletions
diff --git a/cpp/src/qpid/client/Connector.cpp b/cpp/src/qpid/client/Connector.cpp
index 6509964fe8..ea32c4e097 100644
--- a/cpp/src/qpid/client/Connector.cpp
+++ b/cpp/src/qpid/client/Connector.cpp
@@ -197,7 +197,13 @@ TCPConnector::~TCPConnector() {
void TCPConnector::connect(const std::string& host, int port){
Mutex::ScopedLock l(closedLock);
assert(closed);
- socket.connect(host, port);
+ try {
+ socket.connect(host, port);
+ } catch (const std::exception& e) {
+ socket.close();
+ throw;
+ }
+
identifier = str(format("[%1% %2%]") % socket.getLocalPort() % socket.getPeerAddress());
closed = false;
poller = Poller::shared_ptr(new Poller);
diff --git a/cpp/src/qpid/client/SslConnector.cpp b/cpp/src/qpid/client/SslConnector.cpp
index 63f2f1a84f..e821ca4f45 100644
--- a/cpp/src/qpid/client/SslConnector.cpp
+++ b/cpp/src/qpid/client/SslConnector.cpp
@@ -186,7 +186,13 @@ SslConnector::~SslConnector() {
void SslConnector::connect(const std::string& host, int port){
Mutex::ScopedLock l(closedLock);
assert(closed);
- socket.connect(host, port);
+ try {
+ socket.connect(host, port);
+ } catch (const std::exception& e) {
+ socket.close();
+ throw;
+ }
+
identifier = str(format("[%1% %2%]") % socket.getLocalPort() % socket.getPeerAddress());
closed = false;
poller = Poller::shared_ptr(new Poller);