diff options
| author | Gordon Sim <gsim@apache.org> | 2010-06-11 08:42:37 +0000 |
|---|---|---|
| committer | Gordon Sim <gsim@apache.org> | 2010-06-11 08:42:37 +0000 |
| commit | 4467d34858ea0ab6d11fbc90f81162e642fe3133 (patch) | |
| tree | 55725d96eb38456f755e59410253ad6ccb737cf1 /cpp/src/qpid/sys | |
| parent | 85e7cf723b05620e1ed44d50a9533811e823585f (diff) | |
| download | qpid-python-4467d34858ea0ab6d11fbc90f81162e642fe3133.tar.gz | |
Ensure that AsynchConnector is disassociated from Poller when aborting connection attempt due to a heartbeat timeout
git-svn-id: https://svn.apache.org/repos/asf/qpid/trunk/qpid@953610 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'cpp/src/qpid/sys')
| -rw-r--r-- | cpp/src/qpid/sys/AsynchIO.h | 2 | ||||
| -rw-r--r-- | cpp/src/qpid/sys/posix/AsynchIO.cpp | 6 |
2 files changed, 7 insertions, 1 deletions
diff --git a/cpp/src/qpid/sys/AsynchIO.h b/cpp/src/qpid/sys/AsynchIO.h index f1841639ed..50da8fa4fc 100644 --- a/cpp/src/qpid/sys/AsynchIO.h +++ b/cpp/src/qpid/sys/AsynchIO.h @@ -69,7 +69,7 @@ public: ConnectedCallback connCb, FailedCallback failCb); virtual void start(boost::shared_ptr<Poller> poller) = 0; - + virtual void stop() {}; protected: AsynchConnector() {} virtual ~AsynchConnector() {} diff --git a/cpp/src/qpid/sys/posix/AsynchIO.cpp b/cpp/src/qpid/sys/posix/AsynchIO.cpp index cef9f1fcef..7d85b4325b 100644 --- a/cpp/src/qpid/sys/posix/AsynchIO.cpp +++ b/cpp/src/qpid/sys/posix/AsynchIO.cpp @@ -157,6 +157,7 @@ public: ConnectedCallback connCb, FailedCallback failCb); void start(Poller::shared_ptr poller); + void stop(); }; AsynchConnector::AsynchConnector(const Socket& s, @@ -183,6 +184,11 @@ void AsynchConnector::start(Poller::shared_ptr poller) startWatch(poller); } +void AsynchConnector::stop() +{ + stopWatch(); +} + void AsynchConnector::connComplete(DispatchHandle& h) { h.stopWatch(); |
