summaryrefslogtreecommitdiff
path: root/qpid/java
diff options
context:
space:
mode:
authorKeith Wall <kwall@apache.org>2014-12-09 17:36:33 +0000
committerKeith Wall <kwall@apache.org>2014-12-09 17:36:33 +0000
commit7e31771bc163e945510512066608da03ebfe4e52 (patch)
tree804fd2ed93db80cde39f8a68bf790026d859d12b /qpid/java
parent2797e4bed9a3480d795023843efeb2f71ba95392 (diff)
downloadqpid-python-7e31771bc163e945510512066608da03ebfe4e52.tar.gz
Stop reading bytes from the wire once the transport is closed. Also prevent further ByteBuffers being queued to be sent once the transport is closed too
git-svn-id: https://svn.apache.org/repos/asf/qpid/branches/QPID-6262-JavaBrokerNIO@1644128 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'qpid/java')
-rw-r--r--qpid/java/common/src/main/java/org/apache/qpid/transport/network/io/NonBlockingSenderReceiver.java11
1 files changed, 7 insertions, 4 deletions
diff --git a/qpid/java/common/src/main/java/org/apache/qpid/transport/network/io/NonBlockingSenderReceiver.java b/qpid/java/common/src/main/java/org/apache/qpid/transport/network/io/NonBlockingSenderReceiver.java
index f74f934ff3..a6fc3fa148 100644
--- a/qpid/java/common/src/main/java/org/apache/qpid/transport/network/io/NonBlockingSenderReceiver.java
+++ b/qpid/java/common/src/main/java/org/apache/qpid/transport/network/io/NonBlockingSenderReceiver.java
@@ -35,6 +35,7 @@ import org.slf4j.LoggerFactory;
import org.apache.qpid.thread.Threading;
import org.apache.qpid.transport.Receiver;
import org.apache.qpid.transport.Sender;
+import org.apache.qpid.transport.SenderClosedException;
import org.apache.qpid.transport.SenderException;
import org.apache.qpid.transport.network.Ticker;
@@ -104,6 +105,10 @@ public class NonBlockingSenderReceiver implements Runnable, Sender<ByteBuffer>
@Override
public void send(final ByteBuffer msg)
{
+ if (_closed.get())
+ {
+ throw new SenderClosedException("I/O for thread " + _remoteSocketAddress + " is already closed");
+ }
// append to list and do selector wakeup
_buffers.add(msg);
_selector.wakeup();
@@ -223,8 +228,8 @@ public class NonBlockingSenderReceiver implements Runnable, Sender<ByteBuffer>
private void doRead() throws IOException
{
- int remaining;
- do
+ int remaining = 0;
+ while (remaining == 0 && !_closed.get())
{
if(_currentBuffer == null || _currentBuffer.remaining() == 0)
{
@@ -241,7 +246,5 @@ public class NonBlockingSenderReceiver implements Runnable, Sender<ByteBuffer>
_currentBuffer = _currentBuffer.slice();
_receiver.received(dup);
}
- while (remaining == 0);
-
}
}