]> gerrit.simantics Code Review - simantics/platform.git/blobdiff - bundles/org.simantics.databoard/src/org/simantics/databoard/binding/util/RandomValue.java
Fixed all line endings of the repository
[simantics/platform.git] / bundles / org.simantics.databoard / src / org / simantics / databoard / binding / util / RandomValue.java
index 09363921ba21529b249cd52567d824150f9852d0..9fde678737b400c613330407838d42709e0bc166 100644 (file)
@@ -1,63 +1,63 @@
-/*******************************************************************************\r
- *  Copyright (c) 2010 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
+/*******************************************************************************
+ *  Copyright (c) 2010 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.binding.util;
 
-import java.util.HashMap;\r
-import java.util.HashSet;\r
-import java.util.Map;\r
-import java.util.Random;\r
-import java.util.WeakHashMap;\r
-\r
-import org.simantics.databoard.Bindings;\r
-import org.simantics.databoard.Datatypes;\r
-import org.simantics.databoard.adapter.AdaptException;\r
-import org.simantics.databoard.binding.ArrayBinding;\r
-import org.simantics.databoard.binding.Binding;\r
-import org.simantics.databoard.binding.Binding.Visitor;\r
-import org.simantics.databoard.binding.BooleanBinding;\r
-import org.simantics.databoard.binding.ByteBinding;\r
-import org.simantics.databoard.binding.DoubleBinding;\r
-import org.simantics.databoard.binding.FloatBinding;\r
-import org.simantics.databoard.binding.IntegerBinding;\r
-import org.simantics.databoard.binding.LongBinding;\r
-import org.simantics.databoard.binding.MapBinding;\r
-import org.simantics.databoard.binding.OptionalBinding;\r
-import org.simantics.databoard.binding.RecordBinding;\r
-import org.simantics.databoard.binding.StringBinding;\r
-import org.simantics.databoard.binding.UnionBinding;\r
-import org.simantics.databoard.binding.VariantBinding;\r
-import org.simantics.databoard.binding.error.BindingConstructionException;\r
-import org.simantics.databoard.binding.error.BindingException;\r
-import org.simantics.databoard.binding.error.RuntimeBindingConstructionException;\r
-import org.simantics.databoard.binding.error.RuntimeBindingException;\r
-import org.simantics.databoard.binding.factory.BindingScheme;\r
-import org.simantics.databoard.binding.factory.MutableBindingFactory;\r
-import org.simantics.databoard.type.ArrayType;\r
-import org.simantics.databoard.type.BooleanType;\r
-import org.simantics.databoard.type.ByteType;\r
-import org.simantics.databoard.type.Component;\r
-import org.simantics.databoard.type.Datatype;\r
-import org.simantics.databoard.type.DoubleType;\r
-import org.simantics.databoard.type.FloatType;\r
-import org.simantics.databoard.type.IntegerType;\r
-import org.simantics.databoard.type.LongType;\r
-import org.simantics.databoard.type.MapType;\r
-import org.simantics.databoard.type.OptionalType;\r
-import org.simantics.databoard.type.RecordType;\r
-import org.simantics.databoard.type.StringType;\r
-import org.simantics.databoard.type.UnionType;\r
-import org.simantics.databoard.type.VariantType;\r
-import org.simantics.databoard.util.Limit;\r
-import org.simantics.databoard.util.Range;\r
+import java.util.HashMap;
+import java.util.HashSet;
+import java.util.Map;
+import java.util.Random;
+import java.util.WeakHashMap;
+
+import org.simantics.databoard.Bindings;
+import org.simantics.databoard.Datatypes;
+import org.simantics.databoard.adapter.AdaptException;
+import org.simantics.databoard.binding.ArrayBinding;
+import org.simantics.databoard.binding.Binding;
+import org.simantics.databoard.binding.Binding.Visitor;
+import org.simantics.databoard.binding.BooleanBinding;
+import org.simantics.databoard.binding.ByteBinding;
+import org.simantics.databoard.binding.DoubleBinding;
+import org.simantics.databoard.binding.FloatBinding;
+import org.simantics.databoard.binding.IntegerBinding;
+import org.simantics.databoard.binding.LongBinding;
+import org.simantics.databoard.binding.MapBinding;
+import org.simantics.databoard.binding.OptionalBinding;
+import org.simantics.databoard.binding.RecordBinding;
+import org.simantics.databoard.binding.StringBinding;
+import org.simantics.databoard.binding.UnionBinding;
+import org.simantics.databoard.binding.VariantBinding;
+import org.simantics.databoard.binding.error.BindingConstructionException;
+import org.simantics.databoard.binding.error.BindingException;
+import org.simantics.databoard.binding.error.RuntimeBindingConstructionException;
+import org.simantics.databoard.binding.error.RuntimeBindingException;
+import org.simantics.databoard.binding.factory.BindingScheme;
+import org.simantics.databoard.binding.factory.MutableBindingFactory;
+import org.simantics.databoard.type.ArrayType;
+import org.simantics.databoard.type.BooleanType;
+import org.simantics.databoard.type.ByteType;
+import org.simantics.databoard.type.Component;
+import org.simantics.databoard.type.Datatype;
+import org.simantics.databoard.type.DoubleType;
+import org.simantics.databoard.type.FloatType;
+import org.simantics.databoard.type.IntegerType;
+import org.simantics.databoard.type.LongType;
+import org.simantics.databoard.type.MapType;
+import org.simantics.databoard.type.OptionalType;
+import org.simantics.databoard.type.RecordType;
+import org.simantics.databoard.type.StringType;
+import org.simantics.databoard.type.UnionType;
+import org.simantics.databoard.type.VariantType;
+import org.simantics.databoard.util.Limit;
+import org.simantics.databoard.util.Range;
 
 /**
  * Visitor that creates a instance with random value.
@@ -86,8 +86,8 @@ public class RandomValue implements Visitor<Object> {
        public Random random;
        
        /** Map of default values already created. Used to link back to recursive records */
-       Map<Binding, Object> map = new WeakHashMap<Binding, Object>(1);\r
-       \r
+       Map<Binding, Object> map = new WeakHashMap<Binding, Object>(1);
+       
        BindingScheme scheme = new MutableBindingFactory( new HashMap<Datatype, Binding>() );
 
        static String CHARS = "abcdefghijklmnopqrstuvwxyz ,.-'/-+ABCDEFGHIJKLMNOPQRSTUVWXYZ1234567890!\"#�%&/()=\n\\\\r'";
@@ -285,33 +285,33 @@ public class RandomValue implements Visitor<Object> {
        
        @Override
        public Object visit(VariantBinding b) {
-               try {\r
+               try {
                        Object result = pickCached() ? map.get(b) : null;
                        if (result!=null) return result;                
                        
                        int maxDepth = random.nextInt(3)+1;
                        Datatype randomType = randomType(0, maxDepth);
-                       Binding randomBinding;\r
-                       randomBinding = scheme.getBinding( randomType );\r
+                       Binding randomBinding;
+                       randomBinding = scheme.getBinding( randomType );
                        Object randomValue = randomBinding.accept(this);  
                        
                        result = b.createUnchecked(randomBinding, randomValue);
                        map.put(b, result);
                return result;
-               } catch (BindingConstructionException e) {\r
-                       throw new RuntimeBindingConstructionException(e);\r
-               }\r
+               } catch (BindingConstructionException e) {
+                       throw new RuntimeBindingConstructionException(e);
+               }
+       }
+
+       boolean isKeyShortEnough(Binding binding, Object value) {
+               try {
+                       String key;
+                       key = (String) Bindings.adapt(value, binding, Bindings.STR_VARIANT);
+                       return key.length()<=200;
+               } catch (AdaptException e) {
+                       throw new RuntimeException(e);
+               } 
        }
-\r
-       boolean isKeyShortEnough(Binding binding, Object value) {\r
-               try {\r
-                       String key;\r
-                       key = (String) Bindings.adapt(value, binding, Bindings.STR_VARIANT);\r
-                       return key.length()<=200;\r
-               } catch (AdaptException e) {\r
-                       throw new RuntimeException(e);\r
-               } \r
-       }\r
        
        @Override
        public Object visit(MapBinding b) {
@@ -324,19 +324,19 @@ public class RandomValue implements Visitor<Object> {
                Binding valueBinding = b.getValueBinding();
                Object[] keys = new Object[c];
                Object[] values = new Object[c];
-               for (int i=0; i<c; i++) {\r
-                       \r
-                       \r
-                       Object key = null;\r
-                       if (keyBinding.type().equals(Datatypes.VARIANT)) {\r
-                               do {\r
-                                       key = keyBinding.accept(this);\r
-                               } while( !keyBinding.type().equals(Datatypes.VARIANT) || !isKeyShortEnough(keyBinding, key) );                  \r
-                       } else {\r
-                               key = keyBinding.accept(this);                          \r
-                       }\r
+               for (int i=0; i<c; i++) {
+                       
+                       
+                       Object key = null;
+                       if (keyBinding.type().equals(Datatypes.VARIANT)) {
+                               do {
+                                       key = keyBinding.accept(this);
+                               } while( !keyBinding.type().equals(Datatypes.VARIANT) || !isKeyShortEnough(keyBinding, key) );                  
+                       } else {
+                               key = keyBinding.accept(this);                          
+                       }
                        
-                       keys[i] = key;\r
+                       keys[i] = key;
                        
                        values[i] = valueBinding.accept(this);
                }