X-Git-Url: https://gerrit.simantics.org/r/gitweb?a=blobdiff_plain;f=bundles%2Forg.simantics.document.linking.ui%2Fsrc%2Forg%2Fsimantics%2Fdocument%2Flinking%2Freport%2Ftemplates%2FSourceParentDiagramComparator.java;h=edd416478e402a7a6fde9d40193281ff42cc9581;hb=HEAD;hp=59be0c82561dcdc6baf67da0e4f03914a902d00f;hpb=969bd23cab98a79ca9101af33334000879fb60c5;p=simantics%2Fplatform.git diff --git a/bundles/org.simantics.document.linking.ui/src/org/simantics/document/linking/report/templates/SourceParentDiagramComparator.java b/bundles/org.simantics.document.linking.ui/src/org/simantics/document/linking/report/templates/SourceParentDiagramComparator.java index 59be0c825..edd416478 100644 --- a/bundles/org.simantics.document.linking.ui/src/org/simantics/document/linking/report/templates/SourceParentDiagramComparator.java +++ b/bundles/org.simantics.document.linking.ui/src/org/simantics/document/linking/report/templates/SourceParentDiagramComparator.java @@ -1,58 +1,58 @@ -package org.simantics.document.linking.report.templates; - -import java.util.List; - -import org.simantics.db.ReadGraph; -import org.simantics.db.Resource; -import org.simantics.document.linking.ontology.DocumentLink; -import org.simantics.modeling.ModelingResources; - -class SourceParentDiagramComparator extends ResourceNameComparator { - DocumentLink sl; - ModelingResources mod; - - public SourceParentDiagramComparator(ReadGraph graph, Resource model) { - super(graph,model); - sl = DocumentLink.getInstance(graph); - mod = ModelingResources.getInstance(graph); - } - - - @Override - public int compare(Resource o1, Resource o2) { - try { - Resource r1 = graph.getSingleObject(o1, sl.hasSource_Inverse); - Resource r2 = graph.getSingleObject(o2, sl.hasSource_Inverse); - List path1 = getPath(r1); - List path2 = getPath(r2); - int diag1 = -1; - int diag2 = -1; - for (int i = path1.size() -1; i >= 0; i--) { - if (graph.hasStatement(path1.get(i),mod.CompositeToDiagram)) { - diag1 = i; - break; - } - } - for (int i = path2.size() -1; i >= 0; i--) { - if (graph.hasStatement(path2.get(i),mod.CompositeToDiagram)) { - diag2 = i; - break; - } - } - int count = Math.min(diag1, diag2); - - int i = 0; - int comp = 0; - for (; i <= count; i++) { - comp = super.compare(path1.get(i), path2.get(i)); - if (comp != 0) - return comp; - } - return diag1 - diag2; - - } catch (Exception e) { - return 0; - } - - } +package org.simantics.document.linking.report.templates; + +import java.util.List; + +import org.simantics.db.ReadGraph; +import org.simantics.db.Resource; +import org.simantics.document.linking.ontology.DocumentLink; +import org.simantics.modeling.ModelingResources; + +class SourceParentDiagramComparator extends ResourceNameComparator { + DocumentLink sl; + ModelingResources mod; + + public SourceParentDiagramComparator(ReadGraph graph, Resource model) { + super(graph,model); + sl = DocumentLink.getInstance(graph); + mod = ModelingResources.getInstance(graph); + } + + + @Override + public int compare(Resource o1, Resource o2) { + try { + Resource r1 = graph.getSingleObject(o1, sl.hasSource_Inverse); + Resource r2 = graph.getSingleObject(o2, sl.hasSource_Inverse); + List path1 = getPath(r1); + List path2 = getPath(r2); + int diag1 = -1; + int diag2 = -1; + for (int i = path1.size() -1; i >= 0; i--) { + if (graph.hasStatement(path1.get(i),mod.CompositeToDiagram)) { + diag1 = i; + break; + } + } + for (int i = path2.size() -1; i >= 0; i--) { + if (graph.hasStatement(path2.get(i),mod.CompositeToDiagram)) { + diag2 = i; + break; + } + } + int count = Math.min(diag1, diag2); + + int i = 0; + int comp = 0; + for (; i <= count; i++) { + comp = super.compare(path1.get(i), path2.get(i)); + if (comp != 0) + return comp; + } + return diag1 - diag2; + + } catch (Exception e) { + return 0; + } + + } } \ No newline at end of file