You are viewing a plain text version of this content. The canonical link for it is here.
Posted to dev@tomcat.apache.org by ma...@apache.org on 2014/08/18 20:52:04 UTC
svn commit: r1618704 -
/tomcat/trunk/java/org/apache/tomcat/websocket/PerMessageDeflate.java
Author: markt
Date: Mon Aug 18 18:52:04 2014
New Revision: 1618704
URL: http://svn.apache.org/r1618704
Log:
Add a little plumbing for outgoing messages (no actual compression yet)
Make a couple of fields volatile that are accessed by multiple threads (in succession, not in parallel)
Modified:
tomcat/trunk/java/org/apache/tomcat/websocket/PerMessageDeflate.java
Modified: tomcat/trunk/java/org/apache/tomcat/websocket/PerMessageDeflate.java
URL: http://svn.apache.org/viewvc/tomcat/trunk/java/org/apache/tomcat/websocket/PerMessageDeflate.java?rev=1618704&r1=1618703&r2=1618704&view=diff
==============================================================================
--- tomcat/trunk/java/org/apache/tomcat/websocket/PerMessageDeflate.java (original)
+++ tomcat/trunk/java/org/apache/tomcat/websocket/PerMessageDeflate.java Mon Aug 18 18:52:04 2014
@@ -18,6 +18,7 @@ package org.apache.tomcat.websocket;
import java.io.IOException;
import java.nio.ByteBuffer;
+import java.util.ArrayList;
import java.util.List;
import java.util.zip.DataFormatException;
import java.util.zip.Inflater;
@@ -48,8 +49,8 @@ public class PerMessageDeflate implement
private final Inflater inflator = new Inflater(true);
private final ByteBuffer readBuffer = ByteBuffer.allocate(8192);
- private Transformation next;
- private boolean skipDecompression = false;
+ private volatile Transformation next;
+ private volatile boolean skipDecompression = false;
static PerMessageDeflate negotiate(List<List<Parameter>> preferences) {
// Accept the first preference that the server is able to support
@@ -288,11 +289,24 @@ public class PerMessageDeflate implement
@Override
public List<MessagePart> sendMessagePart(List<MessagePart> messageParts) {
- // TODO: Implement compression of sent messages
+ List<MessagePart> compressedParts = new ArrayList<>(messageParts.size());
+
+ for (MessagePart messagePart : messageParts) {
+ byte opCode = messagePart.getOpCode();
+ if (Util.isControl(opCode)) {
+ // Control messages can appear in the middle of other messages
+ // and must not be compressed. Pass it straight through
+ compressedParts.add(messagePart);
+ } else {
+ // TODO: Implement compression of sent messages
+ compressedParts.add(messagePart);
+ }
+ }
+
if (next == null) {
- return messageParts;
+ return compressedParts;
} else {
- return next.sendMessagePart(messageParts);
+ return next.sendMessagePart(compressedParts);
}
}
}
---------------------------------------------------------------------
To unsubscribe, e-mail: dev-unsubscribe@tomcat.apache.org
For additional commands, e-mail: dev-help@tomcat.apache.org