Files
secondo/Algebras/Rose/RoseJava/twodsack/util/comparator/PSPointComparator.java
2026-01-23 17:03:45 +08:00

41 lines
1.7 KiB
Java

/*
* PSPointComparator.java 2005-05-12
*
* Dirk Ansorge, FernUniversitaet Hagen
*
*/
package twodsack.util.comparator;
import twodsack.setelement.datatype.*;
import twodsack.util.collectiontype.*;
import java.util.*;
/**
* A PSPointComparator is used wherever objects of type {@link twodsack.util.collectiontype.PSPoint} shall be inserted in a sorted set working with objects of type {@link twodsack.util.collectiontype.MultiSetEntry}.
* Then, in the constructor an instance of this constructor is needed. It sorts the PSPoint objects by calling the <tt>PSPoint.compare()</tt> method.
*/
public class PSPointComparator implements Comparator {
/**
* Compares both objects and returns one of {0, 1, -1}.
* Calls the <tt>compare()</tt> method for two PSPoint values stored in MultiSetEntry types.
* Returns 0, if both points are equal.<p>
* Returns -1, if <tt>ino1.o</tt> is smaller than <tt>ino2.o</tt>.<p>
* Returns 1 otherwise.
*
* @param ino1 the first object
* @param ino2 the second object
* @return one of {0, 1, -1} as int
* @throws WrongTypeException if one of <tt>ino1.o</tt>, <tt>ono2.o</tt> is not of type PSPoint
*/
public int compare(Object ino1, Object ino2) throws WrongTypeException {
if ((((MultiSetEntry)ino1).value instanceof PSPoint) &&
(((MultiSetEntry)ino2).value instanceof PSPoint))
return ((PSPoint)((MultiSetEntry)ino1).value).compare((PSPoint)((MultiSetEntry)ino2).value);
else
throw new WrongTypeException("in PSPointComparator: Expected PSPoint - found: "+((MultiSetEntry)ino1).value.getClass()+"/"+((MultiSetEntry)ino2).value.getClass());
}//end method compare
}//end class PSPointComparator