]> gerrit.simantics Code Review - simantics/platform.git/blobdiff - bundles/org.simantics.databoard/src/org/simantics/databoard/serialization/impl/MutableVariantSerializer.java
Fixed all line endings of the repository
[simantics/platform.git] / bundles / org.simantics.databoard / src / org / simantics / databoard / serialization / impl / MutableVariantSerializer.java
index 569b05d9d5ddad60d1bb3401b4fbd8d383d25567..5cfe09369d229b3c194332dd71b35145800116eb 100644 (file)
@@ -1,89 +1,89 @@
-/*******************************************************************************\r
- * Copyright (c) 2012 Association for Decentralized Information Management in\r
- * Industry THTH ry.\r
- * All rights reserved. This program and the accompanying materials\r
- * are made available under the terms of the Eclipse Public License v1.0\r
- * which accompanies this distribution, and is available at\r
- * http://www.eclipse.org/legal/epl-v10.html\r
- *\r
- * Contributors:\r
- *     VTT Technical Research Centre of Finland - initial API and implementation\r
- *******************************************************************************/\r
-package org.simantics.databoard.serialization.impl;\r
-\r
-import java.io.DataInput;\r
-import java.io.IOException;\r
-import java.util.ArrayList;\r
-import java.util.List;\r
-\r
-import org.simantics.databoard.Bindings;\r
-import org.simantics.databoard.binding.Binding;\r
-import org.simantics.databoard.binding.VariantBinding;\r
-import org.simantics.databoard.binding.error.BindingException;\r
-import org.simantics.databoard.serialization.Serializer;\r
-import org.simantics.databoard.serialization.SerializerScheme;\r
-import org.simantics.databoard.type.Datatype;\r
-\r
-/**\r
- * A version of VariantSerializer that uses Bindings.getMutableBinding instead\r
- * of Bindings.getBinding for deserialization.\r
- * \r
- * @author Tuukka Lehtonen\r
- */\r
-public class MutableVariantSerializer extends VariantSerializer {\r
-\r
-       public MutableVariantSerializer(VariantBinding binding, SerializerScheme scheme) {\r
-               super(binding, scheme);\r
-       }\r
-\r
-       @Override\r
-       public Object deserialize(DataInput in, List<Object> identities) throws IOException {\r
-               try {\r
-                       List<Object> typeIdentities = new ArrayList<Object>(1);\r
-                       Datatype type = (Datatype) datatypeSerializer.deserialize(in, typeIdentities);\r
-                       Binding valueBinding = Bindings.getMutableBinding(type);\r
-                       Serializer valueSerializer = scheme.getSerializerUnchecked(valueBinding);\r
-                       assertRemainingBytes(in, valueSerializer.getMinSize());\r
-                       Object value = valueSerializer.deserialize(in, identities);\r
-                       return binding.create(valueBinding, value);\r
-               } catch (BindingException e) {\r
-                       throw new IOException( e ); \r
-               }\r
-       }\r
-\r
-       @Override\r
-       public void deserializeTo(DataInput in, List<Object> identities, Object obj) throws IOException {\r
-               try {\r
-                       List<Object> typeIdentities = new ArrayList<Object>(1);\r
-                       Datatype type = (Datatype) datatypeSerializer.deserialize(in, typeIdentities);\r
-                       Datatype oldType = binding.getContentType(obj);\r
-\r
-                       if (type.equals(oldType)) {\r
-                               Binding valueBinding = binding.getContentBinding(obj);\r
-                               Serializer valueSerializer = scheme.getSerializerUnchecked(valueBinding);\r
-                               Object component = binding.getContent(obj);\r
-//                             assertRemainingBytes(in, valueSerializer.getMinSize());\r
-                               component = valueSerializer.deserializeToTry(in, identities, component);\r
-                               binding.setContent(obj, valueBinding, component);\r
-                       } else {\r
-                               Binding valueBinding = Bindings.getMutableBinding(type);\r
-                               Serializer valueSerializer = scheme.getSerializerUnchecked(valueBinding);\r
-//                             assertRemainingBytes(in, valueSerializer.getMinSize());\r
-                               Object component = valueSerializer.deserialize(in, identities);\r
-                               binding.setContent(obj, valueBinding, component);\r
-                       }\r
-               } catch (BindingException e) {\r
-                       throw new IOException( e ); \r
-               }\r
-       }\r
-\r
-       @Override\r
-       public void skip(DataInput in, List<Object> identities) throws IOException {\r
-               List<Object> typeIdentities = new ArrayList<Object>(1);\r
-               Datatype type = (Datatype) datatypeSerializer.deserialize(in, typeIdentities);\r
-               Binding valueBinding = Bindings.getMutableBinding(type);\r
-               Serializer valueSerializer = scheme.getSerializerUnchecked(valueBinding);\r
-               valueSerializer.skip(in, identities);\r
-       }\r
-\r
+/*******************************************************************************
+ * Copyright (c) 2012 Association for Decentralized Information Management in
+ * Industry THTH ry.
+ * All rights reserved. This program and the accompanying materials
+ * are made available under the terms of the Eclipse Public License v1.0
+ * which accompanies this distribution, and is available at
+ * http://www.eclipse.org/legal/epl-v10.html
+ *
+ * Contributors:
+ *     VTT Technical Research Centre of Finland - initial API and implementation
+ *******************************************************************************/
+package org.simantics.databoard.serialization.impl;
+
+import java.io.DataInput;
+import java.io.IOException;
+import java.util.ArrayList;
+import java.util.List;
+
+import org.simantics.databoard.Bindings;
+import org.simantics.databoard.binding.Binding;
+import org.simantics.databoard.binding.VariantBinding;
+import org.simantics.databoard.binding.error.BindingException;
+import org.simantics.databoard.serialization.Serializer;
+import org.simantics.databoard.serialization.SerializerScheme;
+import org.simantics.databoard.type.Datatype;
+
+/**
+ * A version of VariantSerializer that uses Bindings.getMutableBinding instead
+ * of Bindings.getBinding for deserialization.
+ * 
+ * @author Tuukka Lehtonen
+ */
+public class MutableVariantSerializer extends VariantSerializer {
+
+       public MutableVariantSerializer(VariantBinding binding, SerializerScheme scheme) {
+               super(binding, scheme);
+       }
+
+       @Override
+       public Object deserialize(DataInput in, List<Object> identities) throws IOException {
+               try {
+                       List<Object> typeIdentities = new ArrayList<Object>(1);
+                       Datatype type = (Datatype) datatypeSerializer.deserialize(in, typeIdentities);
+                       Binding valueBinding = Bindings.getMutableBinding(type);
+                       Serializer valueSerializer = scheme.getSerializerUnchecked(valueBinding);
+                       assertRemainingBytes(in, valueSerializer.getMinSize());
+                       Object value = valueSerializer.deserialize(in, identities);
+                       return binding.create(valueBinding, value);
+               } catch (BindingException e) {
+                       throw new IOException( e ); 
+               }
+       }
+
+       @Override
+       public void deserializeTo(DataInput in, List<Object> identities, Object obj) throws IOException {
+               try {
+                       List<Object> typeIdentities = new ArrayList<Object>(1);
+                       Datatype type = (Datatype) datatypeSerializer.deserialize(in, typeIdentities);
+                       Datatype oldType = binding.getContentType(obj);
+
+                       if (type.equals(oldType)) {
+                               Binding valueBinding = binding.getContentBinding(obj);
+                               Serializer valueSerializer = scheme.getSerializerUnchecked(valueBinding);
+                               Object component = binding.getContent(obj);
+//                             assertRemainingBytes(in, valueSerializer.getMinSize());
+                               component = valueSerializer.deserializeToTry(in, identities, component);
+                               binding.setContent(obj, valueBinding, component);
+                       } else {
+                               Binding valueBinding = Bindings.getMutableBinding(type);
+                               Serializer valueSerializer = scheme.getSerializerUnchecked(valueBinding);
+//                             assertRemainingBytes(in, valueSerializer.getMinSize());
+                               Object component = valueSerializer.deserialize(in, identities);
+                               binding.setContent(obj, valueBinding, component);
+                       }
+               } catch (BindingException e) {
+                       throw new IOException( e ); 
+               }
+       }
+
+       @Override
+       public void skip(DataInput in, List<Object> identities) throws IOException {
+               List<Object> typeIdentities = new ArrayList<Object>(1);
+               Datatype type = (Datatype) datatypeSerializer.deserialize(in, typeIdentities);
+               Binding valueBinding = Bindings.getMutableBinding(type);
+               Serializer valueSerializer = scheme.getSerializerUnchecked(valueBinding);
+               valueSerializer.skip(in, identities);
+       }
+
 }
\ No newline at end of file