Author: rgodfrey
Date: Fri Nov 13 17:10:06 2015
New Revision: 1714240

URL: http://svn.apache.org/viewvc?rev=1714240&view=rev
Log:
QPID-6840 : Address review comments from [~lorenz.quack]

Modified:
    
qpid/java/trunk/broker-core/src/main/java/org/apache/qpid/server/transport/NonBlockingConnection.java

Modified: 
qpid/java/trunk/broker-core/src/main/java/org/apache/qpid/server/transport/NonBlockingConnection.java
URL: 
http://svn.apache.org/viewvc/qpid/java/trunk/broker-core/src/main/java/org/apache/qpid/server/transport/NonBlockingConnection.java?rev=1714240&r1=1714239&r2=1714240&view=diff
==============================================================================
--- 
qpid/java/trunk/broker-core/src/main/java/org/apache/qpid/server/transport/NonBlockingConnection.java
 (original)
+++ 
qpid/java/trunk/broker-core/src/main/java/org/apache/qpid/server/transport/NonBlockingConnection.java
 Fri Nov 13 17:10:06 2015
@@ -245,31 +245,9 @@ public class NonBlockingConnection imple
                 _protocolEngine.setIOThread(Thread.currentThread());
                 _protocolEngine.setMessageAssignmentSuspended(true);
 
-                if(_pendingIterator == null)
-                {
-                    _pendingIterator = 
_protocolEngine.processPendingIterator();
-                }
+                boolean processPendingComplete = processPending();
 
-                while(_pendingIterator.hasNext())
-                {
-                    long size = getBufferedSize();
-                    if(size >= _port.getNetworkBufferSize())
-                    {
-                        doWrite();
-                        long bytesWritten = size - getBufferedSize();
-                        if(bytesWritten < (_port.getNetworkBufferSize()/2))
-                        {
-                            break;
-                        }
-                    }
-                    else
-                    {
-                        final Runnable task = _pendingIterator.next();
-                        task.run();
-                    }
-                }
-
-                if (!_pendingIterator.hasNext())
+                if(processPendingComplete)
                 {
                     _pendingIterator = null;
                     _protocolEngine.setTransportBlockedForWriting(false);
@@ -326,6 +304,43 @@ public class NonBlockingConnection imple
 
     }
 
+    private boolean processPending() throws IOException
+    {
+        if(_pendingIterator == null)
+        {
+            _pendingIterator = _protocolEngine.processPendingIterator();
+        }
+
+        final int networkBufferSize = _port.getNetworkBufferSize();
+
+        while(_pendingIterator.hasNext())
+        {
+            long size = getBufferedSize();
+            if(size >= networkBufferSize)
+            {
+                doWrite();
+                long bytesWritten = size - getBufferedSize();
+                if(bytesWritten < (networkBufferSize /2))
+                {
+                    break;
+                }
+            }
+            else
+            {
+                final Runnable task = _pendingIterator.next();
+                task.run();
+            }
+        }
+
+        boolean processPendingAndReads = !_pendingIterator.hasNext();
+        if (getBufferedSize() >= networkBufferSize)
+        {
+            doWrite();
+            processPendingAndReads &= getBufferedSize() < networkBufferSize /2;
+        }
+        return processPendingAndReads;
+    }
+
     private long getBufferedSize()
     {
         long totalSize = 0l;



---------------------------------------------------------------------
To unsubscribe, e-mail: [email protected]
For additional commands, e-mail: [email protected]

Reply via email to