type = type.substring(0, type.length() - 2); // remove the []
write(out, type);
- write(out, "\n");
+ write(out, "\r");
try {
for (int i = 0; true; i++) {
Object item = Array.get(value, i);
// encode it normally if direct value
if (!SerialUtils.encode(out, item)) {
try {
- // TODO: use ZIP: if not?
- new Exporter(out).append(item);
+ // TODO: bad escaping?
+ write(out, "B64:");
+ OutputStream bout = StringUtils.base64(out,
+ false, false);
+ new Exporter(bout).append(item);
} catch (NotSerializableException e) {
throw new UnknownFormatConversionException(e
.getMessage());
}
}
- write(out, "\n");
+ write(out, "\r");
}
} catch (ArrayIndexOutOfBoundsException e) {
// Done.
@Override
protected Object fromStream(InputStream in) throws IOException {
NextableInputStream stream = new NextableInputStream(in,
- new NextableInputStreamStep('\n'));
+ new NextableInputStreamStep('\r'));
try {
List<Object> list = new ArrayList<Object>();
// URL:
customTypes.put("java.net.URL", new CustomSerializer() {
-
@Override
protected void toStream(OutputStream out, Object value)
throws IOException {
}
private void encodeRecodeTest(TestCase test, Object data) throws Exception {
- byte[] encoded = toBytes(data);
+ byte[] encoded = toBytes(data,true);
Object redata = fromBytes(encoded);
- byte[] reencoded = toBytes(redata);
+ byte[] reencoded = toBytes(redata,true);
test.assertEquals("Different data after encode/decode/encode", true,
Arrays.equals(encoded, reencoded));
}
// try to remove pointer addresses
- private byte[] toBytes(Object data) throws NotSerializableException,
+ private byte[] toBytes(Object data, boolean clearRefs) throws NotSerializableException,
IOException {
ByteArrayOutputStream out = new ByteArrayOutputStream();
new Exporter(out).append(data);
out.flush();
+
+ if(clearRefs){
String tmp = new String(out.toByteArray(), "UTF-8");
tmp = tmp.replaceAll("@[0-9]*", "@REF");
return tmp.getBytes("UTF-8");
+ }
+
+ return out.toByteArray();
}
private Object fromBytes(byte[] data) throws NoSuchFieldException,
Data[] data = new Data[] { new Data() {
@SuppressWarnings("unused")
int value = 42;
- } };
+ }};
- byte[] encoded = toBytes(data);
+ byte[] encoded = toBytes(data,false);
Object redata = fromBytes(encoded);
// Comparing the 2 arrays won't be useful, because the @REFs
// will be ZIP-encoded; so we parse and re-encode each object
- byte[] encoded1 = toBytes(data[0]);
- byte[] reencoded1 = toBytes(((Data[])redata)[0]);
+ byte[] encoded1 = toBytes(data[0],true);
+ byte[] reencoded1 = toBytes(((Data[])redata)[0],true);
assertEquals("Different data after encode/decode/encode", true,
Arrays.equals(encoded1, reencoded1));