From e0d313a28c9f1bba7ba656fd80fae095034171a6 Mon Sep 17 00:00:00 2001 From: akwizgran <akwizgran@users.sourceforge.net> Date: Fri, 11 Oct 2013 15:16:16 +0100 Subject: [PATCH] Simplified serialisation format: removed compact encodings. --- .../src/net/sf/briar/serial/ReaderImpl.java | 63 +++---------- briar-core/src/net/sf/briar/serial/Tag.java | 9 -- .../src/net/sf/briar/serial/WriterImpl.java | 55 +++-------- .../briar/messaging/PacketReaderImplTest.java | 8 +- .../briar/messaging/PacketWriterImplTest.java | 10 +- .../net/sf/briar/serial/ReaderImplTest.java | 92 ++++--------------- .../net/sf/briar/serial/WriterImplTest.java | 79 ++++------------ 7 files changed, 70 insertions(+), 246 deletions(-) diff --git a/briar-core/src/net/sf/briar/serial/ReaderImpl.java b/briar-core/src/net/sf/briar/serial/ReaderImpl.java index 47f5849ba0..440940d6dc 100644 --- a/briar-core/src/net/sf/briar/serial/ReaderImpl.java +++ b/briar-core/src/net/sf/briar/serial/ReaderImpl.java @@ -250,8 +250,7 @@ class ReaderImpl implements Reader { public boolean hasString() throws IOException { if(!hasLookahead) readLookahead(true); if(eof) return false; - return next == Tag.STRING - || (next & Tag.SHORT_MASK) == Tag.SHORT_STRING; + return next == Tag.STRING; } public String readString() throws IOException { @@ -261,9 +260,7 @@ class ReaderImpl implements Reader { public String readString(int maxLength) throws IOException { if(!hasString()) throw new FormatException(); consumeLookahead(); - int length; - if(next == Tag.STRING) length = readLength(); - else length = 0xFF & next ^ Tag.SHORT_STRING; + int length = readLength(); if(length > maxLength) throw new FormatException(); if(length == 0) return ""; readIntoBuffer(length); @@ -289,7 +286,7 @@ class ReaderImpl implements Reader { public boolean hasBytes() throws IOException { if(!hasLookahead) readLookahead(true); if(eof) return false; - return next == Tag.BYTES || (next & Tag.SHORT_MASK) == Tag.SHORT_BYTES; + return next == Tag.BYTES; } public byte[] readBytes() throws IOException { @@ -299,9 +296,7 @@ class ReaderImpl implements Reader { public byte[] readBytes(int maxLength) throws IOException { if(!hasBytes()) throw new FormatException(); consumeLookahead(); - int length; - if(next == Tag.BYTES) length = readLength(); - else length = 0xFF & next ^ Tag.SHORT_BYTES; + int length = readLength(); if(length > maxLength) throw new FormatException(); if(length == 0) return EMPTY_BUFFER; byte[] b = new byte[length]; @@ -312,29 +307,15 @@ class ReaderImpl implements Reader { public boolean hasList() throws IOException { if(!hasLookahead) readLookahead(true); if(eof) return false; - return next == Tag.LIST - || (next & Tag.SHORT_MASK) == Tag.SHORT_LIST; + return next == Tag.LIST; } public <E> List<E> readList(Class<E> e) throws IOException { if(!hasList()) throw new FormatException(); consumeLookahead(); - if(next == Tag.LIST) { - List<E> list = new ArrayList<E>(); - while(!hasEnd()) list.add(readObject(e)); - readEnd(); - return Collections.unmodifiableList(list); - } else { - int length = 0xFF & next ^ Tag.SHORT_LIST; - return readList(e, length); - } - } - - private <E> List<E> readList(Class<E> e, int length) throws IOException { - assert length >= 0; - if(length == 0) return Collections.emptyList(); List<E> list = new ArrayList<E>(); - for(int i = 0; i < length; i++) list.add(readObject(e)); + while(!hasEnd()) list.add(readObject(e)); + readEnd(); return Collections.unmodifiableList(list); } @@ -419,36 +400,18 @@ class ReaderImpl implements Reader { public boolean hasMap() throws IOException { if(!hasLookahead) readLookahead(true); if(eof) return false; - return next == Tag.MAP - || (next & Tag.SHORT_MASK) == Tag.SHORT_MAP; + return next == Tag.MAP; } public <K, V> Map<K, V> readMap(Class<K> k, Class<V> v) throws IOException { if(!hasMap()) throw new FormatException(); consumeLookahead(); - if(next == Tag.MAP) { - Map<K, V> m = new HashMap<K, V>(); - while(!hasEnd()) { - if(m.put(readObject(k), readObject(v)) != null) - throw new FormatException(); // Duplicate key - } - readEnd(); - return Collections.unmodifiableMap(m); - } else { - int size = 0xFF & next ^ Tag.SHORT_MAP; - return readMap(k, v, size); - } - } - - private <K, V> Map<K, V> readMap(Class<K> k, Class<V> v, int size) - throws IOException { - assert size >= 0; - if(size == 0) return Collections.emptyMap(); Map<K, V> m = new HashMap<K, V>(); - for(int i = 0; i < size; i++) { + while(!hasEnd()) { if(m.put(readObject(k), readObject(v)) != null) throw new FormatException(); // Duplicate key } + readEnd(); return Collections.unmodifiableMap(m); } @@ -486,11 +449,7 @@ class ReaderImpl implements Reader { if(id < 0 || id > 255) throw new IllegalArgumentException(); if(!hasLookahead) readLookahead(true); if(eof) return false; - if(next == Tag.STRUCT) - return id == (0xFF & nextNext); - else if((next & Tag.SHORT_STRUCT_MASK) == Tag.SHORT_STRUCT) - return id == (0xFF & next ^ Tag.SHORT_STRUCT); - else return false; + return id == (0xFF & nextNext); } public void readStructId(int id) throws IOException { diff --git a/briar-core/src/net/sf/briar/serial/Tag.java b/briar-core/src/net/sf/briar/serial/Tag.java index e63b8311f3..04b0e45478 100644 --- a/briar-core/src/net/sf/briar/serial/Tag.java +++ b/briar-core/src/net/sf/briar/serial/Tag.java @@ -17,13 +17,4 @@ interface Tag { byte END = (byte) 0xF3; // 1111 0011 byte NULL = (byte) 0xF2; // 1111 0010 byte STRUCT = (byte) 0xF1; // 1111 0001 - - int SHORT_STRING = 0x80; // 1000 xxxx - int SHORT_BYTES = 0x90; // 1001 xxxx - int SHORT_LIST = 0xA0; // 1010 xxxx - int SHORT_MAP = 0xB0; // 1011 xxxx - int SHORT_STRUCT = 0xC0; // 110x xxxx - - int SHORT_MASK = 0xF0; // Match first four bits - int SHORT_STRUCT_MASK = 0xE0; // Match first three bits } diff --git a/briar-core/src/net/sf/briar/serial/WriterImpl.java b/briar-core/src/net/sf/briar/serial/WriterImpl.java index 8fdd7467b0..aee13708f7 100644 --- a/briar-core/src/net/sf/briar/serial/WriterImpl.java +++ b/briar-core/src/net/sf/briar/serial/WriterImpl.java @@ -111,12 +111,8 @@ class WriterImpl implements Writer { public void writeString(String s) throws IOException { byte[] b = s.getBytes("UTF-8"); - if(b.length < 16) { - write((byte) (Tag.SHORT_STRING | b.length)); - } else { - write(Tag.STRING); - writeLength(b.length); - } + write(Tag.STRING); + writeLength(b.length); write(b); } @@ -129,25 +125,15 @@ class WriterImpl implements Writer { } public void writeBytes(byte[] b) throws IOException { - if(b.length < 16) { - write((byte) (Tag.SHORT_BYTES | b.length)); - } else { - write(Tag.BYTES); - writeLength(b.length); - } + write(Tag.BYTES); + writeLength(b.length); write(b); } public void writeList(Collection<?> c) throws IOException { - int length = c.size(); - if(length < 16) { - write((byte) (Tag.SHORT_LIST | length)); - for(Object o : c) writeObject(o); - } else { - write(Tag.LIST); - for(Object o : c) writeObject(o); - write(Tag.END); - } + write(Tag.LIST); + for(Object o : c) writeObject(o); + write(Tag.END); } private void writeObject(Object o) throws IOException { @@ -175,21 +161,12 @@ class WriterImpl implements Writer { } public void writeMap(Map<?, ?> m) throws IOException { - int length = m.size(); - if(length < 16) { - write((byte) (Tag.SHORT_MAP | length)); - for(Entry<?, ?> e : m.entrySet()) { - writeObject(e.getKey()); - writeObject(e.getValue()); - } - } else { - write(Tag.MAP); - for(Entry<?, ?> e : m.entrySet()) { - writeObject(e.getKey()); - writeObject(e.getValue()); - } - write(Tag.END); + write(Tag.MAP); + for(Entry<?, ?> e : m.entrySet()) { + writeObject(e.getKey()); + writeObject(e.getValue()); } + write(Tag.END); } public void writeMapStart() throws IOException { @@ -206,12 +183,8 @@ class WriterImpl implements Writer { public void writeStructId(int id) throws IOException { if(id < 0 || id > 255) throw new IllegalArgumentException(); - if(id < 32) { - write((byte) (Tag.SHORT_STRUCT | id)); - } else { - write(Tag.STRUCT); - write((byte) id); - } + write(Tag.STRUCT); + write((byte) id); } private void write(byte b) throws IOException { diff --git a/briar-tests/src/net/sf/briar/messaging/PacketReaderImplTest.java b/briar-tests/src/net/sf/briar/messaging/PacketReaderImplTest.java index 92a3c7ce2f..a50b364485 100644 --- a/briar-tests/src/net/sf/briar/messaging/PacketReaderImplTest.java +++ b/briar-tests/src/net/sf/briar/messaging/PacketReaderImplTest.java @@ -214,10 +214,10 @@ public class PacketReaderImplTest extends BriarTestCase { ByteArrayOutputStream out = new ByteArrayOutputStream(); Writer w = writerFactory.createWriter(out); w.writeStructId(REQUEST); - // Allow one byte for the REQUEST tag, one byte for the padding length - // as a uint7, one byte for the BYTES tag, and five bytes for the - // length of the byte array as an int32 - int size = MAX_PACKET_LENGTH - 8; + // Allow one byte for the STRUCT tag, one byte for the REQUEST tag, + // one byte for the padding length as a uint7, one byte for the BYTES + // tag, and five bytes for the length of the byte array as an int32 + int size = MAX_PACKET_LENGTH - 9; if(tooBig) size++; assertTrue(size > Short.MAX_VALUE); w.writeUint7((byte) 0); diff --git a/briar-tests/src/net/sf/briar/messaging/PacketWriterImplTest.java b/briar-tests/src/net/sf/briar/messaging/PacketWriterImplTest.java index c59587185f..2ef9af2e3b 100644 --- a/briar-tests/src/net/sf/briar/messaging/PacketWriterImplTest.java +++ b/briar-tests/src/net/sf/briar/messaging/PacketWriterImplTest.java @@ -60,9 +60,10 @@ public class PacketWriterImplTest extends BriarTestCase { b.set(12); b.set(15); w.writeRequest(new Request(b, 16)); - // Short user tag 5, 0 as uint7, short bytes with length 2, 0xD959 + // STRUCT tag, struct ID 5, 0 as uint7, BYTES tag, length 2 as uint7, + // 0xD959 byte[] output = out.toByteArray(); - assertEquals("C5" + "00" + "92" + "D959", + assertEquals("F1" + "05" + "00" + "F6" + "02" + "D959", StringUtils.toHexString(output)); } @@ -83,9 +84,10 @@ public class PacketWriterImplTest extends BriarTestCase { b.set(11); b.set(12); w.writeRequest(new Request(b, 13)); - // Short user tag 5, 3 as uint7, short bytes with length 2, 0x59D8 + // STRUCT tag, struct ID 5, 3 as uint7, BYTES tag, length 2 as uint7, + // 0xD959 byte[] output = out.toByteArray(); - assertEquals("C5" + "03" + "92" + "59D8", + assertEquals("F1" + "05" + "03" + "F6" + "02" + "59D8", StringUtils.toHexString(output)); } } diff --git a/briar-tests/src/net/sf/briar/serial/ReaderImplTest.java b/briar-tests/src/net/sf/briar/serial/ReaderImplTest.java index 2fff6c6cbe..ec8651d6a8 100644 --- a/briar-tests/src/net/sf/briar/serial/ReaderImplTest.java +++ b/briar-tests/src/net/sf/briar/serial/ReaderImplTest.java @@ -121,17 +121,15 @@ public class ReaderImplTest extends BriarTestCase { @Test public void testReadString() throws Exception { - setContents("F703666F6F" + "83666F6F" + "F700" + "80"); + setContents("F703666F6F" + "F700"); assertEquals("foo", r.readString()); - assertEquals("foo", r.readString()); - assertEquals("", r.readString()); assertEquals("", r.readString()); assertTrue(r.eof()); } @Test public void testReadStringMaxLength() throws Exception { - setContents("83666F6F" + "83666F6F"); + setContents("F703666F6F" + "F703666F6F"); assertEquals("foo", r.readString(3)); try { r.readString(2); @@ -141,17 +139,15 @@ public class ReaderImplTest extends BriarTestCase { @Test public void testReadBytes() throws Exception { - setContents("F603010203" + "93010203" + "F600" + "90"); - assertArrayEquals(new byte[] {1, 2, 3}, r.readBytes()); + setContents("F603010203" + "F600"); assertArrayEquals(new byte[] {1, 2, 3}, r.readBytes()); assertArrayEquals(new byte[] {}, r.readBytes()); - assertArrayEquals(new byte[] {}, r.readBytes()); assertTrue(r.eof()); } @Test public void testReadBytesMaxLength() throws Exception { - setContents("93010203" + "93010203"); + setContents("F603010203" + "F603010203"); assertArrayEquals(new byte[] {1, 2, 3}, r.readBytes(3)); try { r.readBytes(2); @@ -159,21 +155,9 @@ public class ReaderImplTest extends BriarTestCase { } catch(FormatException expected) {} } - @Test - public void testReadShortList() throws Exception { - setContents("A" + "3" + "01" + "83666F6F" + "FC0080"); - List<Object> l = r.readList(Object.class); - assertNotNull(l); - assertEquals(3, l.size()); - assertEquals((byte) 1, l.get(0)); - assertEquals("foo", l.get(1)); - assertEquals((short) 128, l.get(2)); - assertTrue(r.eof()); - } - @Test public void testReadList() throws Exception { - setContents("F5" + "01" + "83666F6F" + "FC0080" + "F3"); + setContents("F5" + "01" + "F703666F6F" + "FC0080" + "F3"); List<Object> l = r.readList(Object.class); assertNotNull(l); assertEquals(3, l.size()); @@ -185,7 +169,7 @@ public class ReaderImplTest extends BriarTestCase { @Test public void testReadListTypeSafe() throws Exception { - setContents("A" + "3" + "01" + "02" + "03"); + setContents("F5" + "01" + "02" + "03" + "F3"); List<Byte> l = r.readList(Byte.class); assertNotNull(l); assertEquals(3, l.size()); @@ -197,7 +181,7 @@ public class ReaderImplTest extends BriarTestCase { @Test public void testReadListTypeSafeThrowsFormatException() throws Exception { - setContents("A" + "3" + "01" + "83666F6F" + "03"); + setContents("F5" + "01" + "F703666F6F" + "03" + "F3"); // Trying to read a mixed list as a list of bytes should throw a // FormatException try { @@ -206,22 +190,9 @@ public class ReaderImplTest extends BriarTestCase { } catch(FormatException expected) {} } - @Test - public void testReadShortMap() throws Exception { - setContents("B" + "2" + "83666F6F" + "7B" + "90" + "F2"); - Map<Object, Object> m = r.readMap(Object.class, Object.class); - assertNotNull(m); - assertEquals(2, m.size()); - assertEquals((byte) 123, m.get("foo")); - Bytes b = new Bytes(new byte[] {}); - assertTrue(m.containsKey(b)); - assertNull(m.get(b)); - assertTrue(r.eof()); - } - @Test public void testReadMap() throws Exception { - setContents("F4" + "83666F6F" + "7B" + "90" + "F2" + "F3"); + setContents("F4" + "F703666F6F" + "7B" + "F600" + "F2" + "F3"); Map<Object, Object> m = r.readMap(Object.class, Object.class); assertNotNull(m); assertEquals(2, m.size()); @@ -234,7 +205,7 @@ public class ReaderImplTest extends BriarTestCase { @Test public void testReadMapTypeSafe() throws Exception { - setContents("B" + "2" + "83666F6F" + "7B" + "80" + "F2"); + setContents("F4" + "F703666F6F" + "7B" + "F700" + "F2" + "F3"); Map<String, Byte> m = r.readMap(String.class, Byte.class); assertNotNull(m); assertEquals(2, m.size()); @@ -246,8 +217,8 @@ public class ReaderImplTest extends BriarTestCase { @Test public void testMapKeysMustBeUnique() throws Exception { - setContents("B" + "2" + "83666F6F" + "01" + "83626172" + "02" - + "B" + "2" + "83666F6F" + "01" + "83666F6F" + "02"); + setContents("F4" + "F703666F6F" + "01" + "F703626172" + "02" + "F3" + + "F4" + "F703666F6F" + "01" + "F703666F6F" + "02" + "F3"); // The first map has unique keys Map<String, Byte> m = r.readMap(String.class, Byte.class); assertNotNull(m); @@ -261,21 +232,9 @@ public class ReaderImplTest extends BriarTestCase { } catch(FormatException expected) {} } - @Test - public void testReadDelimitedList() throws Exception { - setContents("F5" + "01" + "83666F6F" + "FC0080" + "F3"); - List<Object> l = r.readList(Object.class); - assertNotNull(l); - assertEquals(3, l.size()); - assertEquals((byte) 1, l.get(0)); - assertEquals("foo", l.get(1)); - assertEquals((short) 128, l.get(2)); - assertTrue(r.eof()); - } - @Test public void testReadDelimitedListElements() throws Exception { - setContents("F5" + "01" + "83666F6F" + "FC0080" + "F3"); + setContents("F5" + "01" + "F703666F6F" + "FC0080" + "F3"); assertTrue(r.hasListStart()); r.readListStart(); assertFalse(r.hasListEnd()); @@ -301,22 +260,9 @@ public class ReaderImplTest extends BriarTestCase { assertTrue(r.eof()); } - @Test - public void testReadDelimitedMap() throws Exception { - setContents("F4" + "83666F6F" + "7B" + "90" + "F2" + "F3"); - Map<Object, Object> m = r.readMap(Object.class, Object.class); - assertNotNull(m); - assertEquals(2, m.size()); - assertEquals((byte) 123, m.get("foo")); - Bytes b = new Bytes(new byte[] {}); - assertTrue(m.containsKey(b)); - assertNull(m.get(b)); - assertTrue(r.eof()); - } - @Test public void testReadDelimitedMapEntries() throws Exception { - setContents("F4" + "83666F6F" + "7B" + "90" + "F2" + "F3"); + setContents("F4" + "F703666F6F" + "7B" + "F600" + "F2" + "F3"); assertTrue(r.hasMapStart()); r.readMapStart(); assertFalse(r.hasMapEnd()); @@ -335,7 +281,7 @@ public class ReaderImplTest extends BriarTestCase { @Test public void testReadDelimitedMapTypeSafe() throws Exception { - setContents("F4" + "83666F6F" + "7B" + "80" + "F2" + "F3"); + setContents("F4" + "F703666F6F" + "7B" + "F700" + "F2" + "F3"); Map<String, Byte> m = r.readMap(String.class, Byte.class); assertNotNull(m); assertEquals(2, m.size()); @@ -348,8 +294,8 @@ public class ReaderImplTest extends BriarTestCase { @Test @SuppressWarnings("unchecked") public void testReadNestedMapsAndLists() throws Exception { - setContents("B" + "1" + "B" + "1" + "83666F6F" + "7B" - + "A" + "1" + "01"); + setContents("F4" + "F4" + "F703666F6F" + "7B" + "F3" + + "F5" + "01" + "F3" + "F3"); Map<Object, Object> m = r.readMap(Object.class, Object.class); assertNotNull(m); assertEquals(1, m.size()); @@ -368,7 +314,7 @@ public class ReaderImplTest extends BriarTestCase { @Test public void testMaxLengthAppliesInsideMap() throws Exception { - setContents("B" + "1" + "83666F6F" + "93010203"); + setContents("F4" + "F703666F6F" + "F603010203" + "F3"); r.setMaxStringLength(3); r.setMaxBytesLength(3); Map<String, Bytes> m = r.readMap(String.class, Bytes.class); @@ -376,14 +322,14 @@ public class ReaderImplTest extends BriarTestCase { Bytes value = new Bytes(new byte[] {1, 2, 3}); assertEquals(Collections.singletonMap(key, value), m); // The max string length should be applied inside the map - setContents("B" + "1" + "83666F6F" + "93010203"); + setContents("F4" + "F703666F6F" + "F603010203" + "F3"); r.setMaxStringLength(2); try { r.readMap(String.class, Bytes.class); fail(); } catch(FormatException expected) {} // The max bytes length should be applied inside the map - setContents("B" + "1" + "83666F6F" + "93010203"); + setContents("F4" + "F703666F6F" + "F603010203" + "F3"); r.setMaxBytesLength(2); try { r.readMap(String.class, Bytes.class); diff --git a/briar-tests/src/net/sf/briar/serial/WriterImplTest.java b/briar-tests/src/net/sf/briar/serial/WriterImplTest.java index ec3958baf5..398c818411 100644 --- a/briar-tests/src/net/sf/briar/serial/WriterImplTest.java +++ b/briar-tests/src/net/sf/briar/serial/WriterImplTest.java @@ -133,13 +133,6 @@ public class WriterImplTest extends BriarTestCase { + "F8" + "7FF0000000000000" + "F8" + "7FF8000000000000"); } - @Test - public void testWriteShortString() throws IOException { - w.writeString("foo bar baz bam"); - // SHORT_STRING tag, length 15, UTF-8 bytes - checkContents("8" + "F" + "666F6F206261722062617A2062616D"); - } - @Test public void testWriteString() throws IOException { w.writeString("foo bar baz bam "); @@ -147,15 +140,6 @@ public class WriterImplTest extends BriarTestCase { checkContents("F7" + "10" + "666F6F206261722062617A2062616D20"); } - @Test - public void testWriteShortBytes() throws IOException { - w.writeBytes(new byte[] { - 0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14 - }); - // SHORT_BYTES tag, length 15, bytes - checkContents("9" + "F" + "000102030405060708090A0B0C0D0E"); - } - @Test public void testWriteBytes() throws IOException { w.writeBytes(new byte[] { @@ -165,15 +149,6 @@ public class WriterImplTest extends BriarTestCase { checkContents("F6" + "10" + "000102030405060708090A0B0C0D0E0F"); } - @Test - public void testWriteShortList() throws IOException { - List<Object> l = new ArrayList<Object>(); - for(int i = 0; i < 15; i++) l.add(i); - w.writeList(l); - // SHORT_LIST tag, length, elements as uint7 - checkContents("A" + "F" + "000102030405060708090A0B0C0D0E"); - } - @Test public void testWriteList() throws IOException { List<Object> l = new ArrayList<Object>(); @@ -190,20 +165,8 @@ public class WriterImplTest extends BriarTestCase { l.add(null); l.add(2); w.writeList(l); - // SHORT_LIST tag, length, 1 as uint7, null, 2 as uint7 - checkContents("A" + "3" + "01" + "F2" + "02"); - } - - @Test - public void testWriteShortMap() throws IOException { - // Use LinkedHashMap to get predictable iteration order - Map<Object, Object> m = new LinkedHashMap<Object, Object>(); - for(int i = 0; i < 15; i++) m.put(i, i + 1); - w.writeMap(m); - // SHORT_MAP tag, size, entries as uint7 - checkContents("B" + "F" + "0001" + "0102" + "0203" + "0304" + "0405" - + "0506" + "0607" + "0708" + "0809" + "090A" + "0A0B" + "0B0C" - + "0C0D" + "0D0E" + "0E0F"); + // LIST tag, 1 as uint7, null, 2 as uint7, END tag + checkContents("F5" + "01" + "F2" + "02" + "F3"); } @Test @@ -222,25 +185,24 @@ public class WriterImplTest extends BriarTestCase { public void testWriteDelimitedList() throws IOException { w.writeListStart(); w.writeIntAny((byte) 1); // Written as uint7 - w.writeString("foo"); // Written as short string - w.writeIntAny(128L); // Written as an int16 + w.writeString("foo"); // Written as string + w.writeIntAny(128L); // Written as int16 w.writeListEnd(); - // LIST tag, 1 as uint7, "foo" as short string, 128 as int16, - // END tag - checkContents("F5" + "01" + "83666F6F" + "FC0080" + "F3"); + // LIST tag, 1 as uint7, "foo" as string, 128 as int16, END tag + checkContents("F5" + "01" + "F703666F6F" + "FC0080" + "F3"); } @Test public void testWriteDelimitedMap() throws IOException { w.writeMapStart(); - w.writeString("foo"); // Written as short string - w.writeIntAny(123); // Written as a uint7 - w.writeBytes(new byte[] {}); // Written as short bytes + w.writeString("foo"); // Written as string + w.writeIntAny(123); // Written as uint7 + w.writeBytes(new byte[0]); // Written as bytes w.writeNull(); w.writeMapEnd(); - // MAP tag, "foo" as short string, 123 as uint7, - // byte[] {} as short bytes, NULL tag, END tag - checkContents("F4" + "83666F6F" + "7B" + "90" + "F2" + "F3"); + // MAP tag, "foo" as string, 123 as uint7, byte[0] as bytes, + // NULL tag, END tag + checkContents("F4" + "F703666F6F" + "7B" + "F600" + "F2" + "F3"); } @Test @@ -252,10 +214,10 @@ public class WriterImplTest extends BriarTestCase { Map<Object, Object> m1 = new LinkedHashMap<Object, Object>(); m1.put(m, l); w.writeMap(m1); - // SHORT_MAP tag, length 1, SHORT_MAP tag, length 1, - // "foo" as short string, 123 as uint7, SHORT_LIST tag, length 1, - // 1 as uint7 - checkContents("B" + "1" + "B" + "1" + "83666F6F" + "7B" + "A1" + "01"); + // MAP tag, MAP tag, "foo" as string, 123 as uint7, END tag, + // LIST tag, 1 as uint7, END tag, END tag + checkContents("F4" + "F4" + "F703666F6F" + "7B" + "F3" + + "F5" + "01" + "F3" + "F3"); } @Test @@ -264,15 +226,6 @@ public class WriterImplTest extends BriarTestCase { checkContents("F2"); } - @Test - public void testWriteShortStructId() throws IOException { - w.writeStructId(0); - w.writeStructId(31); - // SHORT_STRUCT tag (3 bits), 0 (5 bits), SHORT_STRUCT tag (3 bits), - // 31 (5 bits) - checkContents("C0" + "DF"); - } - @Test public void testWriteStructId() throws IOException { w.writeStructId(32); -- GitLab