summaryrefslogtreecommitdiff
path: root/java/common/src
diff options
context:
space:
mode:
authorRafael H. Schloming <rhs@apache.org>2007-09-20 15:05:57 +0000
committerRafael H. Schloming <rhs@apache.org>2007-09-20 15:05:57 +0000
commit47327bc045ac163808f2097ce1a12ac0f0327b40 (patch)
treec609ebe380a1b2a327fefcf16df1ba566f57719c /java/common/src
parentef8c465d84471330b6c17cdd2b98fb166ff94e57 (diff)
downloadqpid-python-47327bc045ac163808f2097ce1a12ac0f0327b40.tar.gz
added frame-end constant
git-svn-id: https://svn.apache.org/repos/asf/incubator/qpid/trunk/qpid@577785 13f79535-47bb-0310-9956-ffa450edef68
Diffstat (limited to 'java/common/src')
-rw-r--r--java/common/src/main/java/org/apache/qpidity/transport/network/InputHandler.java8
-rw-r--r--java/common/src/main/java/org/apache/qpidity/transport/network/OutputHandler.java5
2 files changed, 11 insertions, 2 deletions
diff --git a/java/common/src/main/java/org/apache/qpidity/transport/network/InputHandler.java b/java/common/src/main/java/org/apache/qpidity/transport/network/InputHandler.java
index 191f900c02..7293193c02 100644
--- a/java/common/src/main/java/org/apache/qpidity/transport/network/InputHandler.java
+++ b/java/common/src/main/java/org/apache/qpidity/transport/network/InputHandler.java
@@ -22,6 +22,7 @@ package org.apache.qpidity.transport.network;
import java.nio.ByteBuffer;
+import org.apache.qpidity.transport.Constant;
import org.apache.qpidity.transport.ProtocolError;
import org.apache.qpidity.transport.ProtocolHeader;
import org.apache.qpidity.transport.Receiver;
@@ -62,6 +63,7 @@ public class InputHandler implements Receiver<ByteBuffer>
FRAME_HDR_RSVD5,
FRAME_PAYLOAD,
FRAME_FRAGMENT,
+ FRAME_END,
ERROR;
}
@@ -189,7 +191,7 @@ public class InputHandler implements Receiver<ByteBuffer>
buf.position(buf.position() + size);
frame.addFragment(payload);
frame();
- return FRAME_HDR;
+ return FRAME_END;
}
case FRAME_FRAGMENT:
int delta = size - frame.getSize();
@@ -203,8 +205,10 @@ public class InputHandler implements Receiver<ByteBuffer>
buf.position(buf.position() + delta);
frame.addFragment(fragment);
frame();
- return FRAME_HDR;
+ return FRAME_END;
}
+ case FRAME_END:
+ return expect(buf, Constant.FRAME_END, FRAME_HDR);
default:
throw new IllegalStateException();
}
diff --git a/java/common/src/main/java/org/apache/qpidity/transport/network/OutputHandler.java b/java/common/src/main/java/org/apache/qpidity/transport/network/OutputHandler.java
index 90bef36790..ee936f6503 100644
--- a/java/common/src/main/java/org/apache/qpidity/transport/network/OutputHandler.java
+++ b/java/common/src/main/java/org/apache/qpidity/transport/network/OutputHandler.java
@@ -22,6 +22,7 @@ package org.apache.qpidity.transport.network;
import java.nio.ByteBuffer;
+import org.apache.qpidity.transport.Constant;
import org.apache.qpidity.transport.ProtocolError;
import org.apache.qpidity.transport.ProtocolHeader;
import org.apache.qpidity.transport.Sender;
@@ -88,6 +89,10 @@ public class OutputHandler implements Sender<NetworkEvent>, NetworkDelegate
{
sender.send(buf);
}
+ ByteBuffer end = ByteBuffer.allocate(1);
+ end.put((byte) Constant.FRAME_END);
+ end.flip();
+ sender.send(end);
}
}