X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=blobdiff_plain;f=bundles%2Forg.simantics.databoard%2Fsrc%2Forg%2Fsimantics%2Fdataboard%2Fserialization%2Fimpl%2FLongArraySerializer.java;h=af5342d004f11833aeb076d945a9ecb82db91fdf;hb=HEAD;hp=003b175fd7457e85014b1001a0e4ceefabce7179;hpb=969bd23cab98a79ca9101af33334000879fb60c5;p=simantics%2Fplatform.git diff --git a/bundles/org.simantics.databoard/src/org/simantics/databoard/serialization/impl/LongArraySerializer.java b/bundles/org.simantics.databoard/src/org/simantics/databoard/serialization/impl/LongArraySerializer.java index 003b175fd..af5342d00 100644 --- a/bundles/org.simantics.databoard/src/org/simantics/databoard/serialization/impl/LongArraySerializer.java +++ b/bundles/org.simantics.databoard/src/org/simantics/databoard/serialization/impl/LongArraySerializer.java @@ -1,108 +1,108 @@ -package org.simantics.databoard.serialization.impl; - -import java.io.DataInput; -import java.io.DataOutput; -import java.io.IOException; -import java.util.List; - -import org.simantics.databoard.binding.ArrayBinding; -import org.simantics.databoard.binding.error.BindingException; -import org.simantics.databoard.serialization.SerializationException; -import org.simantics.databoard.serialization.Serializer.NonRecursiveSerializer; -import org.simantics.databoard.type.ArrayType; -import org.simantics.databoard.util.Range; - -public class LongArraySerializer extends NonRecursiveSerializer { - - Range length; - Integer fixedLength, fixedSize; - - public LongArraySerializer(ArrayBinding binding) - { - ArrayType arrayType = (ArrayType) binding.type(); - this.length = arrayType.getLength(); - if (length!=null && length.getLower().equals(length.getUpper()) && length.getLower().getValue()!=null) - { - fixedLength = length.getLower().getValue().intValue(); - fixedSize = fixedLength * 8; - } - } - - @Override - public Object deserialize(DataInput in) - throws IOException - { - int length = fixedSize != null ? fixedLength : in.readInt(); - if (length<0) throw new SerializationException("Cannot use negative array length"); - assertRemainingBytes(in, length*8L); - - long[] array = new long[length]; - for(int i=0;i identities, Object obj) throws IOException - { - int length = fixedLength != null ? fixedLength : in.readInt(); - long[] array = (long[]) obj; - if (length!=array.length) array = new long[ length ]; - assertRemainingBytes(in, length*8L); - - for (int i=0; i identities, Object obj) throws IOException + { + int length = fixedLength != null ? fixedLength : in.readInt(); + long[] array = (long[]) obj; + if (length!=array.length) array = new long[ length ]; + assertRemainingBytes(in, length*8L); + + for (int i=0; i