diff options
| author | Andrew Stitcher <astitcher@apache.org> | 2010-09-08 16:49:14 +0000 |
|---|---|---|
| committer | Andrew Stitcher <astitcher@apache.org> | 2010-09-08 16:49:14 +0000 |
| commit | 3a6c30bed7555502928da4a7e11debb7cefa375d (patch) | |
| tree | bafaf78cea3c637d36f8fcfb42f9b7f8da3263b3 /qpid/cpp | |
| parent | 72e3a776d9b0eedf9519b67c900e6006f100d90a (diff) | |
| download | qpid-python-3a6c30bed7555502928da4a7e11debb7cefa375d.tar.gz | |
Reorder some code for improved intellegibility
git-svn-id: https://svn.apache.org/repos/asf/qpid/trunk@995135 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'qpid/cpp')
| -rw-r--r-- | qpid/cpp/src/qpid/sys/rdma/RdmaIO.cpp | 25 |
1 files changed, 10 insertions, 15 deletions
diff --git a/qpid/cpp/src/qpid/sys/rdma/RdmaIO.cpp b/qpid/cpp/src/qpid/sys/rdma/RdmaIO.cpp index 52de923248..6591c6e676 100644 --- a/qpid/cpp/src/qpid/sys/rdma/RdmaIO.cpp +++ b/qpid/cpp/src/qpid/sys/rdma/RdmaIO.cpp @@ -94,14 +94,11 @@ namespace Rdma { //qpid::sys::ScopedLock<qpid::sys::Mutex> l(stateLock); do { newState = oldState = state.get(); - doReturn = false; - if (oldState != IDLE && oldState != DRAINED) { - doReturn = true; - break; + doReturn = true; + if (oldState == IDLE || oldState == DRAINED) { + doReturn = false; + newState = SHUTDOWN; } - - newState = SHUTDOWN; - } while (!state.boolCompareAndSwap(oldState, newState)); // Ensure we can't get any more callbacks (except for the stopped callback) @@ -125,14 +122,12 @@ namespace Rdma { //qpid::sys::ScopedLock<qpid::sys::Mutex> l(stateLock); do { newState = oldState = state.get(); - doReturn = false; - if (oldState != IDLE) { - doReturn = true; - break; - } - - if (outstandingWrites == 0) { - newState = DRAINED; + doReturn = true; + if (oldState == IDLE) { + doReturn = false; + if (outstandingWrites == 0) { + newState = DRAINED; + } } } while (!state.boolCompareAndSwap(oldState, newState)); if (doReturn) { |
