Change 64 to 63 in Snappy.decodeLiteral

Motivation:

According to https://github.com/google/snappy/blob/master/format_description.txt#L55 , Snappy.decodeLiteral should handle the cases of 60, 61, 62 and 63. However right now it processes 64 instead of 63. I believe it's a typo since `tag >> 2 & 0x3F` must be less than 64.

Modifications:

Use the correct value 63.

Result:

Snappy.decodeLiteral handles the correct case.
This commit is contained in:
Xiaoyan Lin 2016-01-19 15:10:15 -08:00 committed by Norman Maurer
parent ae6c74d51a
commit 5466f68f78
2 changed files with 31 additions and 3 deletions

View File

@ -229,7 +229,7 @@ class Snappy {
* @param out The output buffer to copy to * @param out The output buffer to copy to
* @param length The length of the literal to copy * @param length The length of the literal to copy
*/ */
private static void encodeLiteral(ByteBuf in, ByteBuf out, int length) { static void encodeLiteral(ByteBuf in, ByteBuf out, int length) {
if (length < 61) { if (length < 61) {
out.writeByte(length - 1 << 2); out.writeByte(length - 1 << 2);
} else { } else {
@ -396,7 +396,7 @@ class Snappy {
* @param out The output buffer to write the literal to * @param out The output buffer to write the literal to
* @return The number of bytes appended to the output buffer, or -1 to indicate "try again later" * @return The number of bytes appended to the output buffer, or -1 to indicate "try again later"
*/ */
private static int decodeLiteral(byte tag, ByteBuf in, ByteBuf out) { static int decodeLiteral(byte tag, ByteBuf in, ByteBuf out) {
in.markReaderIndex(); in.markReaderIndex();
int length; int length;
switch(tag >> 2 & 0x3F) { switch(tag >> 2 & 0x3F) {
@ -418,7 +418,7 @@ class Snappy {
} }
length = ByteBufUtil.swapMedium(in.readUnsignedMedium()); length = ByteBufUtil.swapMedium(in.readUnsignedMedium());
break; break;
case 64: case 63:
if (in.readableBytes() < 4) { if (in.readableBytes() < 4) {
return NOT_ENOUGH_INPUT; return NOT_ENOUGH_INPUT;
} }

View File

@ -195,4 +195,32 @@ public class SnappyTest {
validateChecksum(maskChecksum(0xd6cb8b55), input); validateChecksum(maskChecksum(0xd6cb8b55), input);
} }
@Test
public void testEncodeLiteralAndDecodeLiteral() {
int[] lengths = new int[] {
0x11, // default
0x100, // case 60
0x1000, // case 61
0x100000, // case 62
0x1000001 // case 63
};
for (int len : lengths) {
ByteBuf in = Unpooled.wrappedBuffer(new byte[len]);
ByteBuf encoded = Unpooled.buffer(10);
ByteBuf decoded = Unpooled.buffer(10);
ByteBuf expected = Unpooled.wrappedBuffer(new byte[len]);
try {
Snappy.encodeLiteral(in, encoded, len);
byte tag = encoded.readByte();
Snappy.decodeLiteral(tag, encoded, decoded);
assertEquals("Encoded or decoded literal was incorrect", expected, decoded);
} finally {
in.release();
encoded.release();
decoded.release();
expected.release();
}
}
}
} }