Implementation of CustomBinaryStruct Serializer done

This commit is contained in:
Ziver Koc 2016-04-14 13:15:49 +02:00
parent 6071ad7c70
commit e41fe70951
5 changed files with 111 additions and 52 deletions

View file

@ -59,7 +59,7 @@ public class BinaryFieldData {
}
}
protected void setValue(Object obj, byte[] data){
protected void setByteValue(Object obj, byte[] data){
try {
field.setAccessible(true);
if (field.getType() == Boolean.class || field.getType() == boolean.class)
@ -74,8 +74,16 @@ public class BinaryFieldData {
e.printStackTrace();
}
}
protected void setValue(Object obj, Object value){
try {
field.setAccessible(true);
field.set(obj, value);
} catch (IllegalAccessException e){
e.printStackTrace();
}
}
protected byte[] getValue(Object obj){
protected byte[] getByteValue(Object obj){
try {
field.setAccessible(true);
if (field.getType() == Boolean.class || field.getType() == boolean.class)
@ -91,10 +99,22 @@ public class BinaryFieldData {
}
return null;
}
protected Object getValue(Object obj){
try {
field.setAccessible(true);
return field.get(obj);
} catch (IllegalAccessException e) {
e.printStackTrace();
}
return null;
}
public int getBitLength(){
return length;
}
public BinaryFieldSerializer getSerializer(){
return serializer;
}
}

View file

@ -25,17 +25,10 @@
package zutil.parser.binary;
import zutil.ByteUtil;
import zutil.converter.Converter;
import zutil.parser.binary.BinaryStruct.BinaryField;
import java.io.ByteArrayInputStream;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.lang.reflect.Field;
import java.util.ArrayList;
import java.util.Collections;
import java.util.HashMap;
import java.util.List;
/**
@ -78,6 +71,11 @@ public class BinaryStructInputStream {
int totalReadLength = 0;
for (BinaryFieldData field : structDataList){
if (field.getSerializer() != null){
Object value = field.getSerializer().read(in, field);
field.setValue(struct, value);
}
else {
byte[] valueData = new byte[(int) Math.ceil(field.getBitLength() / 8.0)];
int fieldReadLength = 0;
@ -93,9 +91,10 @@ public class BinaryStructInputStream {
dataBitIndex -= bitLength;
}
// Set value
field.setValue(struct, valueData);
field.setByteValue(struct, valueData);
totalReadLength += fieldReadLength;
}
}
return totalReadLength;
}

View file

@ -73,7 +73,12 @@ public class BinaryStructOutputStream {
List<BinaryFieldData> structDataList = BinaryFieldData.getStructFieldList(struct.getClass());
for (BinaryFieldData field : structDataList){
byte[] data = field.getValue(struct);
if (field.getSerializer() != null){
localFlush();
field.getSerializer().write(out, field.getValue(struct), field);
}
else{
byte[] data = field.getByteValue(struct);
int fieldBitLength = field.getBitLength();
for (int i = (int) Math.ceil(fieldBitLength / 8.0) - 1; fieldBitLength > 0; fieldBitLength -= 8, --i) {
@ -91,6 +96,7 @@ public class BinaryStructOutputStream {
}
}
}
}
/**

View file

@ -26,6 +26,10 @@ package zutil.parser.binary;
import org.junit.Test;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import static junit.framework.TestCase.assertEquals;
import static junit.framework.TestCase.assertFalse;
@ -125,4 +129,29 @@ public class BinaryStructInputStreamTest {
BinaryStructInputStream.read(struct, new byte[]{0b0000_0001,0b0001_1000,0b0000_0000});
struct.assertObj();
}
@Test
public void customBinaryField(){
BinaryTestStruct struct = new BinaryTestStruct() {
@CustomBinaryField(index=1, serializer=ByteStringSerializer.class)
public String s1;
public void assertObj(){
assertEquals("1234", s1);
}
};
BinaryStructInputStream.read(struct, new byte[]{0b0000_0001,0b0000_0010,0b0000_0011,0b0000_0100});
struct.assertObj();
}
public static class ByteStringSerializer implements BinaryFieldSerializer<String>{
public String read(InputStream in, BinaryFieldData field) throws IOException {
String ret = "";
for (int c; (c=in.read()) > 0; )
ret += c;
return ret;
}
public void write(OutputStream out, String obj, BinaryFieldData field) throws IOException {}
}
}

View file

@ -26,10 +26,10 @@ package zutil.parser.binary;
import org.junit.Test;
import java.io.ByteArrayOutputStream;
import java.io.IOException;
import java.io.InputStream;
import java.io.OutputStream;
import static junit.framework.TestCase.assertEquals;
import static org.junit.Assert.assertArrayEquals;
@ -77,20 +77,25 @@ public class BinaryStructOutputStreamTest {
byte[] data = BinaryStructOutputStream.serialize(struct);
assertArrayEquals(new byte[]{(byte)0b0100_0000}, data);
}
/*
@Test
public void basicStringTest(){
BinaryTestStruct struct = new BinaryTestStruct() {
@BinaryField(index=1, length=8*12)
public String s1;
public void assertObj(Object... expected){
assertEquals(s1, "hello world!");
}
@Test
public void customBinaryField() throws IOException {
BinaryStruct struct = new BinaryStruct() {
@BinaryStruct.CustomBinaryField(index=1, serializer=ByteStringSerializer.class)
public String s1 = "1234";
};
BinaryStructParser.parse(struct, "hello world!".getBytes());
struct.assertObj();
byte[] data = BinaryStructOutputStream.serialize(struct);
assertArrayEquals(new byte[]{0b0000_0001,0b0000_0010,0b0000_0011,0b0000_0100}, data);
}
public static class ByteStringSerializer implements BinaryFieldSerializer<String>{
public String read(InputStream in, BinaryFieldData field) throws IOException {
return null;
}
public void write(OutputStream out, String obj, BinaryFieldData field) throws IOException {
for (char c : obj.toCharArray())
out.write(Integer.parseInt(""+c));
}
}
*/
}