]> gerrit.simantics Code Review - simantics/platform.git/blobdiff - bundles/org.simantics.modeling/src/org/simantics/modeling/subscription/AddSubscription.java
Fixed all line endings of the repository
[simantics/platform.git] / bundles / org.simantics.modeling / src / org / simantics / modeling / subscription / AddSubscription.java
index 6bc3506e082c2533969c229faa80093b741fc192..0c8140b53df67e572aac7f1c52a2d5bdd1c16b75 100644 (file)
-/*******************************************************************************\r
- * Copyright (c) 2007, 2011 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.modeling.subscription;\r
-\r
-import java.util.Collection;\r
-import java.util.UUID;\r
-\r
-import org.eclipse.core.runtime.preferences.IEclipsePreferences;\r
-import org.eclipse.core.runtime.preferences.InstanceScope;\r
-import org.simantics.databoard.Bindings;\r
-import org.simantics.databoard.Databoard;\r
-import org.simantics.databoard.annotations.Optional;\r
-import org.simantics.databoard.binding.Binding;\r
-import org.simantics.databoard.type.Datatype;\r
-import org.simantics.databoard.util.Bean;\r
-import org.simantics.db.Resource;\r
-import org.simantics.db.WriteGraph;\r
-import org.simantics.db.common.request.ObjectsWithType;\r
-import org.simantics.db.common.request.WriteRequest;\r
-import org.simantics.db.common.utils.NameUtils;\r
-import org.simantics.db.exception.DatabaseException;\r
-import org.simantics.db.layer0.util.RemoverUtil;\r
-import org.simantics.db.layer0.variable.RVI;\r
-import org.simantics.layer0.Layer0;\r
-import org.simantics.modeling.ModelingResources;\r
-import org.simantics.modeling.preferences.SubscriptionPreferences;\r
-\r
-\r
-public class AddSubscription extends WriteRequest {\r
-\r
-    Resource         container;\r
-    String           subscriptionName;\r
-    Collection<Item> items;\r
-    boolean          overwrite;\r
-\r
-    public AddSubscription(Resource container, String subscriptionName, Collection<Item> items, boolean overwrite) {\r
-        this.container = container;\r
-        this.subscriptionName = subscriptionName; \r
-        this.items = items;\r
-        this.overwrite = overwrite;\r
-    }\r
-\r
-    @Override\r
-    public void perform(WriteGraph graph) throws DatabaseException {\r
-        Layer0 l0 = Layer0.getInstance(graph);\r
-        ModelingResources mod = ModelingResources.getInstance(graph);\r
-\r
-        IEclipsePreferences pn = InstanceScope.INSTANCE.getNode( SubscriptionPreferences.P_NODE );\r
-        Double defaultSubscriptionItemInterval = pn.getDouble(SubscriptionPreferences.P_SUBSCRIPTION_INTERVAL, SubscriptionPreferences.DEFAULT_SUBSCRIPTION_INTERVAL);\r
-        Double defaultSubscriptionItemDeadband = pn.getDouble(SubscriptionPreferences.P_SUBSCRIPTION_DEADBAND, SubscriptionPreferences.DEFAULT_SUBSCRIPTION_DEADBAND); \r
-\r
-        if (overwrite) {\r
-            for (Resource existing : graph.syncRequest(new ObjectsWithType(container, l0.ConsistsOf, mod.Subscription))) {\r
-                String name = graph.getPossibleRelatedValue(existing, l0.HasName, Bindings.STRING);\r
-                if (subscriptionName.equals(name)) {\r
-                    RemoverUtil.remove(graph, existing);\r
-                }\r
-            }\r
-        }\r
-\r
-        Resource subscription = graph.newResource();\r
-        graph.claim(subscription, l0.InstanceOf, null, mod.Subscription);\r
-        String freshName = NameUtils.findFreshName(graph, subscriptionName, container);\r
-        graph.claimLiteral(subscription, l0.HasName, freshName);\r
-        graph.claimLiteral(subscription, l0.HasLabel, freshName);\r
-        graph.claim(container, l0.ConsistsOf, subscription);\r
-\r
-       Binding rviBinding = graph.getService(Databoard.class).getBindingUnchecked( RVI.class );\r
-        for (Item item : items) {\r
-            Resource subscriptionItem = graph.newResource();\r
-            graph.claim(subscriptionItem, l0.InstanceOf, null, mod.Subscription_Item);\r
-            graph.claim(subscription, l0.ConsistsOf, subscriptionItem);\r
-            graph.claimLiteral(subscriptionItem, l0.HasName, UUID.randomUUID().toString(), Bindings.STRING);\r
-            if ( item.label!= null) graph.claimLiteral(subscriptionItem, l0.HasLabel, item.label, Bindings.STRING);\r
-            \r
-            graph.claimLiteral(subscriptionItem, mod.Subscription_Item_VariableId, l0.RVI, item.resolvedName, rviBinding);\r
-\r
-            Double interval = item.interval!=null ? item.interval : defaultSubscriptionItemInterval;\r
-            if (interval != null) {\r
-                graph.claimLiteral(subscriptionItem, mod.Subscription_Item_SamplingInterval, interval, Bindings.DOUBLE);\r
-            }\r
-            \r
-            Double deadband = item.deadband!=null ? item.deadband : defaultSubscriptionItemDeadband;\r
-            if (deadband != null) {\r
-                graph.claimLiteral(subscriptionItem, mod.Subscription_Item_Deadband, deadband, Bindings.DOUBLE);\r
-            }\r
-\r
-            if (item.gain != null) {\r
-                graph.claimLiteral(subscriptionItem, mod.Subscription_Item_Gain, item.gain, Bindings.DOUBLE);\r
-            }\r
-            \r
-            if (item.bias != null) {\r
-                graph.claimLiteral(subscriptionItem, mod.Subscription_Item_Deadband, item.bias, Bindings.DOUBLE);\r
-            }                \r
-            \r
-            if (item.datatype != null)\r
-                graph.claimLiteral(subscriptionItem, mod.Subscription_Item_Datatype,\r
-                        l0.DataType, item.datatype,\r
-                        Bindings.getBindingUnchecked(Datatype.class));\r
-        }\r
-    }\r
-\r
-    public static class Item extends Bean {\r
-       public RVI resolvedName;\r
-        public @Optional Double interval, deadband, gain, bias;\r
-        public @Optional String label;\r
-        public @Optional Datatype datatype;\r
-    }\r
-\r
-}\r
+/*******************************************************************************
+ * Copyright (c) 2007, 2011 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.modeling.subscription;
+
+import java.util.Collection;
+import java.util.UUID;
+
+import org.eclipse.core.runtime.preferences.IEclipsePreferences;
+import org.eclipse.core.runtime.preferences.InstanceScope;
+import org.simantics.databoard.Bindings;
+import org.simantics.databoard.Databoard;
+import org.simantics.databoard.annotations.Optional;
+import org.simantics.databoard.binding.Binding;
+import org.simantics.databoard.type.Datatype;
+import org.simantics.databoard.util.Bean;
+import org.simantics.db.Resource;
+import org.simantics.db.WriteGraph;
+import org.simantics.db.common.request.ObjectsWithType;
+import org.simantics.db.common.request.WriteRequest;
+import org.simantics.db.common.utils.NameUtils;
+import org.simantics.db.exception.DatabaseException;
+import org.simantics.db.layer0.util.RemoverUtil;
+import org.simantics.db.layer0.variable.RVI;
+import org.simantics.layer0.Layer0;
+import org.simantics.modeling.ModelingResources;
+import org.simantics.modeling.preferences.SubscriptionPreferences;
+
+
+public class AddSubscription extends WriteRequest {
+
+    Resource         container;
+    String           subscriptionName;
+    Collection<Item> items;
+    boolean          overwrite;
+
+    public AddSubscription(Resource container, String subscriptionName, Collection<Item> items, boolean overwrite) {
+        this.container = container;
+        this.subscriptionName = subscriptionName; 
+        this.items = items;
+        this.overwrite = overwrite;
+    }
+
+    @Override
+    public void perform(WriteGraph graph) throws DatabaseException {
+        Layer0 l0 = Layer0.getInstance(graph);
+        ModelingResources mod = ModelingResources.getInstance(graph);
+
+        IEclipsePreferences pn = InstanceScope.INSTANCE.getNode( SubscriptionPreferences.P_NODE );
+        Double defaultSubscriptionItemInterval = pn.getDouble(SubscriptionPreferences.P_SUBSCRIPTION_INTERVAL, SubscriptionPreferences.DEFAULT_SUBSCRIPTION_INTERVAL);
+        Double defaultSubscriptionItemDeadband = pn.getDouble(SubscriptionPreferences.P_SUBSCRIPTION_DEADBAND, SubscriptionPreferences.DEFAULT_SUBSCRIPTION_DEADBAND); 
+
+        if (overwrite) {
+            for (Resource existing : graph.syncRequest(new ObjectsWithType(container, l0.ConsistsOf, mod.Subscription))) {
+                String name = graph.getPossibleRelatedValue(existing, l0.HasName, Bindings.STRING);
+                if (subscriptionName.equals(name)) {
+                    RemoverUtil.remove(graph, existing);
+                }
+            }
+        }
+
+        Resource subscription = graph.newResource();
+        graph.claim(subscription, l0.InstanceOf, null, mod.Subscription);
+        String freshName = NameUtils.findFreshName(graph, subscriptionName, container);
+        graph.claimLiteral(subscription, l0.HasName, freshName);
+        graph.claimLiteral(subscription, l0.HasLabel, freshName);
+        graph.claim(container, l0.ConsistsOf, subscription);
+
+       Binding rviBinding = graph.getService(Databoard.class).getBindingUnchecked( RVI.class );
+        for (Item item : items) {
+            Resource subscriptionItem = graph.newResource();
+            graph.claim(subscriptionItem, l0.InstanceOf, null, mod.Subscription_Item);
+            graph.claim(subscription, l0.ConsistsOf, subscriptionItem);
+            graph.claimLiteral(subscriptionItem, l0.HasName, UUID.randomUUID().toString(), Bindings.STRING);
+            if ( item.label!= null) graph.claimLiteral(subscriptionItem, l0.HasLabel, item.label, Bindings.STRING);
+            
+            graph.claimLiteral(subscriptionItem, mod.Subscription_Item_VariableId, l0.RVI, item.resolvedName, rviBinding);
+
+            Double interval = item.interval!=null ? item.interval : defaultSubscriptionItemInterval;
+            if (interval != null) {
+                graph.claimLiteral(subscriptionItem, mod.Subscription_Item_SamplingInterval, interval, Bindings.DOUBLE);
+            }
+            
+            Double deadband = item.deadband!=null ? item.deadband : defaultSubscriptionItemDeadband;
+            if (deadband != null) {
+                graph.claimLiteral(subscriptionItem, mod.Subscription_Item_Deadband, deadband, Bindings.DOUBLE);
+            }
+
+            if (item.gain != null) {
+                graph.claimLiteral(subscriptionItem, mod.Subscription_Item_Gain, item.gain, Bindings.DOUBLE);
+            }
+            
+            if (item.bias != null) {
+                graph.claimLiteral(subscriptionItem, mod.Subscription_Item_Deadband, item.bias, Bindings.DOUBLE);
+            }                
+            
+            if (item.datatype != null)
+                graph.claimLiteral(subscriptionItem, mod.Subscription_Item_Datatype,
+                        l0.DataType, item.datatype,
+                        Bindings.getBindingUnchecked(Datatype.class));
+        }
+    }
+
+    public static class Item extends Bean {
+       public RVI resolvedName;
+        public @Optional Double interval, deadband, gain, bias;
+        public @Optional String label;
+        public @Optional Datatype datatype;
+    }
+
+}