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%2FSourceParentComparator.java;h=82bafbed534e45da63daa2f5ebcfe16cbd75c907;hb=HEAD;hp=f926ecfb7ad212f37323df5122d6f21aa4eecac4;hpb=969bd23cab98a79ca9101af33334000879fb60c5;p=simantics%2Fplatform.git diff --git a/bundles/org.simantics.document.linking.ui/src/org/simantics/document/linking/report/templates/SourceParentComparator.java b/bundles/org.simantics.document.linking.ui/src/org/simantics/document/linking/report/templates/SourceParentComparator.java index f926ecfb7..82bafbed5 100644 --- a/bundles/org.simantics.document.linking.ui/src/org/simantics/document/linking/report/templates/SourceParentComparator.java +++ b/bundles/org.simantics.document.linking.ui/src/org/simantics/document/linking/report/templates/SourceParentComparator.java @@ -1,38 +1,38 @@ -package org.simantics.document.linking.report.templates; - -import org.simantics.db.ReadGraph; -import org.simantics.db.Resource; -import org.simantics.document.linking.ontology.DocumentLink; - -class SourceParentComparator extends ResourceNameComparator { - DocumentLink sl; - public SourceParentComparator(ReadGraph graph, Resource model) { - super(graph,model); - sl = DocumentLink.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); - int comp = super.compare(r1,r2); - if (comp == 0) { - Resource rel1 = graph.getPossibleObject(o1, sl.consernsRelation); - Resource rel2 = graph.getPossibleObject(o2, sl.consernsRelation); - if (rel1 != null) { - if (rel2 != null) - return super.compare(rel1,rel2); - return 1; - } else if (rel2 != null) - return -1; - return 0; - } else { - return comp; - } - } catch (Exception e) { - return 0; - } - - } +package org.simantics.document.linking.report.templates; + +import org.simantics.db.ReadGraph; +import org.simantics.db.Resource; +import org.simantics.document.linking.ontology.DocumentLink; + +class SourceParentComparator extends ResourceNameComparator { + DocumentLink sl; + public SourceParentComparator(ReadGraph graph, Resource model) { + super(graph,model); + sl = DocumentLink.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); + int comp = super.compare(r1,r2); + if (comp == 0) { + Resource rel1 = graph.getPossibleObject(o1, sl.consernsRelation); + Resource rel2 = graph.getPossibleObject(o2, sl.consernsRelation); + if (rel1 != null) { + if (rel2 != null) + return super.compare(rel1,rel2); + return 1; + } else if (rel2 != null) + return -1; + return 0; + } else { + return comp; + } + } catch (Exception e) { + return 0; + } + + } } \ No newline at end of file