X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=blobdiff_plain;f=bundles%2Forg.simantics.modeling%2Fsrc%2Forg%2Fsimantics%2Fmodeling%2FModelingUtils.java;h=a42e51a162e190e05497a5f15918fbc1fac15eef;hb=HEAD;hp=1edf3cd3121a4e4682e5de0012916fcfd0b74ee5;hpb=9214a600c9401b06057fc2c10ea86a0ce0218d87;p=simantics%2Fplatform.git diff --git a/bundles/org.simantics.modeling/src/org/simantics/modeling/ModelingUtils.java b/bundles/org.simantics.modeling/src/org/simantics/modeling/ModelingUtils.java index 1edf3cd31..a42e51a16 100644 --- a/bundles/org.simantics.modeling/src/org/simantics/modeling/ModelingUtils.java +++ b/bundles/org.simantics.modeling/src/org/simantics/modeling/ModelingUtils.java @@ -70,6 +70,7 @@ import org.simantics.db.Session; import org.simantics.db.Statement; import org.simantics.db.VirtualGraph; import org.simantics.db.WriteGraph; +import org.simantics.db.WriteOnlyGraph; import org.simantics.db.common.Indexing; import org.simantics.db.common.NamedResource; import org.simantics.db.common.QueryMemoryWatcher; @@ -82,10 +83,10 @@ import org.simantics.db.common.request.ObjectsWithType; import org.simantics.db.common.request.PossibleIndexRoot; import org.simantics.db.common.request.ReadRequest; import org.simantics.db.common.request.ResourceRead2; +import org.simantics.db.common.request.WriteOnlyRequest; import org.simantics.db.common.request.WriteRequest; import org.simantics.db.common.request.WriteResultRequest; import org.simantics.db.common.utils.ListUtils; -import org.simantics.db.common.utils.Logger; import org.simantics.db.common.utils.NameUtils; import org.simantics.db.common.utils.OrderedSetUtils; import org.simantics.db.common.utils.VersionInfo; @@ -123,7 +124,6 @@ import org.simantics.db.layer0.util.SimanticsKeys; import org.simantics.db.layer0.util.TransferableGraphConfiguration2; import org.simantics.db.layer0.variable.Variable; import org.simantics.db.layer0.variable.Variables; -import org.simantics.db.request.Read; import org.simantics.db.service.ClusterControl; import org.simantics.db.service.CollectionSupport; import org.simantics.db.service.GraphChangeListenerSupport; @@ -166,12 +166,16 @@ import org.simantics.utils.datastructures.Pair; import org.simantics.utils.datastructures.Triple; import org.simantics.utils.datastructures.hints.HintContext; import org.simantics.utils.ui.dialogs.ListDialog; +import org.slf4j.Logger; +import org.slf4j.LoggerFactory; /** * @author Hannu Niemistö */ public class ModelingUtils { + private static final Logger LOGGER = LoggerFactory.getLogger(ModelingUtils.class); + private ReadGraph g; private WriteGraph wg; public Layer0 b; @@ -478,7 +482,7 @@ public class ModelingUtils { } catch (Exception e) { - Logger.defaultLogError(e); + LOGGER.error("Model import failed", e); } } @@ -598,7 +602,9 @@ public class ModelingUtils { } public static void untrackDependencies() { - untrackDependencies(Simantics.getSession()); + Session s = Simantics.peekSession(); + if (s != null) + untrackDependencies(s); } public static void untrackDependencies(RequestProcessor processor) { @@ -615,7 +621,7 @@ public class ModelingUtils { }); } catch (DatabaseException e) { - Logger.defaultLogError(e); + LOGGER.error("untrackDependenices failed", e); } } @@ -638,7 +644,7 @@ public class ModelingUtils { }); } catch (DatabaseException e) { - Logger.defaultLogError(e); + LOGGER.error("trackDependenices failed", e); } } @@ -1256,7 +1262,7 @@ public class ModelingUtils { return advisor.getRoot(); } catch (Throwable t) { - Logger.defaultLogError("Unexpected exception while importing diagram template.", t); + LOGGER.error("Unexpected exception while importing diagram template.", t); } finally { } @@ -1442,7 +1448,7 @@ public class ModelingUtils { Variant draftStatus = dc.metadata.get(DraftStatusBean.EXTENSION_KEY); return MigrationUtils.importSharedOntology(Simantics.getSession(), tg, draftStatus == null); } catch (Exception e) { - Logger.defaultLogError(e); + LOGGER.error("importSharedOntologyWithResult failed", e); throw e; } } @@ -2459,16 +2465,34 @@ public class ModelingUtils { return DiagramGraphUtil.getModelingRules(graph, diagramResource, null); } + //------------------------------------------------------------------------- + + private static final String VG_CHANGE_INFORMATION = "changeInformation"; //$NON-NLS-1$ + public static void markChanged(WriteGraph graph, Resource r) throws DatabaseException { - VirtualGraphSupport support = Simantics.getSession().getService(VirtualGraphSupport.class); - VirtualGraph vg = support.getWorkspacePersistent("changeInformation"); - graph.syncRequest(new WriteRequest(vg) { + VirtualGraph vg = Simantics.getSession().getService(VirtualGraphSupport.class) + .getWorkspacePersistent(VG_CHANGE_INFORMATION); + ModelingResources MOD = ModelingResources.getInstance(graph); + graph.syncRequest(new WriteOnlyRequest(vg) { @Override - public void perform(WriteGraph graph) throws DatabaseException { - ModelingResources MOD = ModelingResources.getInstance(graph); + public void perform(WriteOnlyGraph graph) throws DatabaseException { graph.claim(r, MOD.changed, MOD.changed, r); } }); } - + + public static void markChanged(RequestProcessor processor, Iterable rs) throws DatabaseException { + VirtualGraph vg = Simantics.getSession().getService(VirtualGraphSupport.class) + .getWorkspacePersistent(VG_CHANGE_INFORMATION); + ModelingResources MOD = ModelingResources.getInstance(processor); + processor.syncRequest(new WriteOnlyRequest(vg) { + @Override + public void perform(WriteOnlyGraph graph) throws DatabaseException { + for (Resource r : rs) { + graph.claim(r, MOD.changed, MOD.changed, r); + } + } + }); + } + }