diff --git a/protege-editor-owl/src/main/java/org/protege/editor/owl/ui/OWLPropertyAssertionRowComparator.java b/protege-editor-owl/src/main/java/org/protege/editor/owl/ui/OWLPropertyAssertionRowComparator.java new file mode 100644 index 000000000..3dfd47579 --- /dev/null +++ b/protege-editor-owl/src/main/java/org/protege/editor/owl/ui/OWLPropertyAssertionRowComparator.java @@ -0,0 +1,42 @@ +package org.protege.editor.owl.ui; + +import org.protege.editor.owl.ui.frame.OWLFrameSectionRow; +import org.semanticweb.owlapi.model.OWLIndividual; +import org.semanticweb.owlapi.model.OWLObject; +import org.semanticweb.owlapi.model.OWLPropertyAssertionAxiom; + +import java.util.Comparator; + +/** + * Compares rows of type {@link OWLPropertyAssertionAxiom}. + * Comparison priority is as follows: + * inference > property > object + *

+ * Author: Michael Opitz
+ * https://github.com/mmopitz
+ * Date: 30-Sep-2024

+ */ +public class OWLPropertyAssertionRowComparator, PAIR> implements + Comparator> { + private final Comparator delegate; + + public OWLPropertyAssertionRowComparator(Comparator delegate) { + this.delegate = delegate; + } + + + @Override + public int compare(OWLFrameSectionRow o1, OWLFrameSectionRow o2) { + if (o1.isInferred() && !o2.isInferred()) { + return 1; + } + else if (o2.isInferred() && !o1.isInferred()) { + return -1; + } + int comparison = delegate.compare(o1.getAxiom().getProperty(), o2.getAxiom().getProperty()); + if (comparison != 0) { + return comparison; + } + return delegate.compare(o1.getAxiom().getObject(), o2.getAxiom().getObject()); + } +} diff --git a/protege-editor-owl/src/main/java/org/protege/editor/owl/ui/frame/individual/OWLDataPropertyAssertionAxiomFrameSection.java b/protege-editor-owl/src/main/java/org/protege/editor/owl/ui/frame/individual/OWLDataPropertyAssertionAxiomFrameSection.java index d1b0ff072..4cfccda20 100644 --- a/protege-editor-owl/src/main/java/org/protege/editor/owl/ui/frame/individual/OWLDataPropertyAssertionAxiomFrameSection.java +++ b/protege-editor-owl/src/main/java/org/protege/editor/owl/ui/frame/individual/OWLDataPropertyAssertionAxiomFrameSection.java @@ -2,6 +2,7 @@ import org.protege.editor.owl.OWLEditorKit; import org.protege.editor.owl.model.inference.ReasonerPreferences.OptionalInferenceTask; +import org.protege.editor.owl.ui.OWLPropertyAssertionRowComparator; import org.protege.editor.owl.ui.editor.OWLDataPropertyRelationshipEditor; import org.protege.editor.owl.ui.editor.OWLObjectEditor; import org.protege.editor.owl.ui.frame.AbstractOWLFrameSection; @@ -106,7 +107,7 @@ public OWLObjectEditor getObjectEditor() { * or null if the rows shouldn't be sorted. */ public Comparator> getRowComparator() { - return null; + return new OWLPropertyAssertionRowComparator<>(getOWLModelManager().getOWLObjectComparator()); } @Override diff --git a/protege-editor-owl/src/main/java/org/protege/editor/owl/ui/frame/individual/OWLNegativeDataPropertyAssertionFrameSection.java b/protege-editor-owl/src/main/java/org/protege/editor/owl/ui/frame/individual/OWLNegativeDataPropertyAssertionFrameSection.java index 6e2383098..c49e98912 100644 --- a/protege-editor-owl/src/main/java/org/protege/editor/owl/ui/frame/individual/OWLNegativeDataPropertyAssertionFrameSection.java +++ b/protege-editor-owl/src/main/java/org/protege/editor/owl/ui/frame/individual/OWLNegativeDataPropertyAssertionFrameSection.java @@ -1,6 +1,7 @@ package org.protege.editor.owl.ui.frame.individual; import org.protege.editor.owl.OWLEditorKit; +import org.protege.editor.owl.ui.OWLPropertyAssertionRowComparator; import org.protege.editor.owl.ui.editor.OWLDataPropertyRelationshipEditor; import org.protege.editor.owl.ui.editor.OWLObjectEditor; import org.protege.editor.owl.ui.frame.AbstractOWLFrameSection; @@ -73,7 +74,7 @@ public OWLObjectEditor getObjectEditor() { * or null if the rows shouldn't be sorted. */ public Comparator> getRowComparator() { - return null; + return new OWLPropertyAssertionRowComparator<>(getOWLModelManager().getOWLObjectComparator()); } @Override diff --git a/protege-editor-owl/src/main/java/org/protege/editor/owl/ui/frame/individual/OWLNegativeObjectPropertyAssertionFrameSection.java b/protege-editor-owl/src/main/java/org/protege/editor/owl/ui/frame/individual/OWLNegativeObjectPropertyAssertionFrameSection.java index ce8c07186..cd14b8750 100644 --- a/protege-editor-owl/src/main/java/org/protege/editor/owl/ui/frame/individual/OWLNegativeObjectPropertyAssertionFrameSection.java +++ b/protege-editor-owl/src/main/java/org/protege/editor/owl/ui/frame/individual/OWLNegativeObjectPropertyAssertionFrameSection.java @@ -1,6 +1,7 @@ package org.protege.editor.owl.ui.frame.individual; import org.protege.editor.owl.OWLEditorKit; +import org.protege.editor.owl.ui.OWLPropertyAssertionRowComparator; import org.protege.editor.owl.ui.editor.OWLObjectEditor; import org.protege.editor.owl.ui.editor.OWLObjectPropertyIndividualPairEditor2; import org.protege.editor.owl.ui.frame.AbstractOWLFrameSection; @@ -70,7 +71,7 @@ public OWLObjectEditor getObjectEditor() { * or null if the rows shouldn't be sorted. */ public Comparator> getRowComparator() { - return null; + return new OWLPropertyAssertionRowComparator<>(getOWLModelManager().getOWLObjectComparator()); } @Override diff --git a/protege-editor-owl/src/main/java/org/protege/editor/owl/ui/frame/individual/OWLObjectPropertyAssertionAxiomFrameSection.java b/protege-editor-owl/src/main/java/org/protege/editor/owl/ui/frame/individual/OWLObjectPropertyAssertionAxiomFrameSection.java index 790b63fae..98d874633 100644 --- a/protege-editor-owl/src/main/java/org/protege/editor/owl/ui/frame/individual/OWLObjectPropertyAssertionAxiomFrameSection.java +++ b/protege-editor-owl/src/main/java/org/protege/editor/owl/ui/frame/individual/OWLObjectPropertyAssertionAxiomFrameSection.java @@ -2,6 +2,7 @@ import org.protege.editor.owl.OWLEditorKit; import org.protege.editor.owl.model.inference.ReasonerPreferences.OptionalInferenceTask; +import org.protege.editor.owl.ui.OWLPropertyAssertionRowComparator; import org.protege.editor.owl.ui.editor.OWLObjectEditor; import org.protege.editor.owl.ui.editor.OWLObjectPropertyIndividualPairEditor2; import org.protege.editor.owl.ui.frame.AbstractOWLFrameSection; @@ -106,7 +107,7 @@ public OWLObjectEditor getObjectEditor() { * or null if the rows shouldn't be sorted. */ public Comparator> getRowComparator() { - return null; + return new OWLPropertyAssertionRowComparator<>(getOWLModelManager().getOWLObjectComparator()); } @Override diff --git a/protege-editor-owl/src/test/java/org/protege/editor/owl/ui/OWLPropertyAssertionRowComparator_TestCase.java b/protege-editor-owl/src/test/java/org/protege/editor/owl/ui/OWLPropertyAssertionRowComparator_TestCase.java new file mode 100644 index 000000000..ee57746b3 --- /dev/null +++ b/protege-editor-owl/src/test/java/org/protege/editor/owl/ui/OWLPropertyAssertionRowComparator_TestCase.java @@ -0,0 +1,95 @@ +package org.protege.editor.owl.ui; + +import org.junit.Before; +import org.junit.Test; +import org.junit.runner.RunWith; +import org.mockito.Mock; +import org.mockito.runners.MockitoJUnitRunner; +import org.protege.editor.owl.ui.frame.OWLFrameSectionRow; +import org.semanticweb.owlapi.model.*; + +import java.util.Comparator; + +import static org.junit.Assert.assertEquals; +import static org.mockito.Mockito.when; + +@RunWith(MockitoJUnitRunner.class) +public class OWLPropertyAssertionRowComparator_TestCase { + + @Mock + Comparator delegate; + @Mock + OWLFrameSectionRow o1; + @Mock + OWLFrameSectionRow o2; + @Mock + OWLObjectPropertyAssertionAxiom opa1; + @Mock + OWLObjectPropertyAssertionAxiom opa2; + @Mock + OWLObjectProperty op1; + @Mock + OWLObjectProperty op2; + @Mock + OWLIndividual i1; + @Mock + OWLIndividual i2; + + OWLPropertyAssertionRowComparator comparator; + + @Before + public void setUp() { + comparator = new OWLPropertyAssertionRowComparator<>(delegate); + } + + @Test + public void testInferred1() { + when(o1.isInferred()).thenReturn(true); + when(o2.isInferred()).thenReturn(false); + assertEquals(1, comparator.compare(o1, o2)); + } + + @Test + public void testInferred2() { + when(o1.isInferred()).thenReturn(false); + when(o2.isInferred()).thenReturn(true); + assertEquals(-1, comparator.compare(o1, o2)); + } + + @Test + public void testDifferentProperty() { + when(o1.getAxiom()).thenReturn(opa1); + when(o2.getAxiom()).thenReturn(opa2); + when(opa1.getProperty()).thenReturn(op1); + when(opa2.getProperty()).thenReturn(op2); + when(delegate.compare(op1, op2)).thenReturn(-2); + assertEquals(-2, comparator.compare(o1, o2)); + } + + @Test + public void testDifferentIndividuals() { + when(o1.getAxiom()).thenReturn(opa1); + when(o2.getAxiom()).thenReturn(opa2); + when(opa1.getProperty()).thenReturn(op1); + when(opa2.getProperty()).thenReturn(op2); + when(opa1.getObject()).thenReturn(i1); + when(opa2.getObject()).thenReturn(i2); + when(delegate.compare(op1, op2)).thenReturn(0); + when(delegate.compare(i1, i2)).thenReturn(-2); + assertEquals(-2, comparator.compare(o1, o2)); + } + + @Test + public void testSame() { + when(o1.getAxiom()).thenReturn(opa1); + when(o2.getAxiom()).thenReturn(opa2); + when(opa1.getProperty()).thenReturn(op1); + when(opa2.getProperty()).thenReturn(op2); + when(opa1.getObject()).thenReturn(i1); + when(opa2.getObject()).thenReturn(i2); + when(delegate.compare(op1, op2)).thenReturn(0); + when(delegate.compare(i1, i2)).thenReturn(0); + assertEquals(0, comparator.compare(o1, o2)); + } + +} \ No newline at end of file