All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.github.j5ik2o.intervals.UpperLowerOrdering.scala Maven / Gradle / Ivy

There is a newer version: 1.0.59
Show newest version
package com.github.j5ik2o.intervals

/** 区間同士の比較を行うための`Ordering`の実装(上側優先)
  *
  * 上側限界による比較を優先し、同じであったら下側限界による比較を採用する。
  *
  * @param inverseLower
  *   下限が逆順の場合は`true`
  * @param inverseUpper
  *   上限が逆順の場合は`false`
  */
class UpperLowerOrdering[T](private val inverseLower: Boolean, private val inverseUpper: Boolean)
    extends Ordering[Interval[T]] {

  private[this] val lowerFactor = if (inverseLower) -1 else 1
  private[this] val upperFactor = if (inverseUpper) -1 else 1

  override def compare(e1: Interval[T], e2: Interval[T]): Int =
    if (e1.isEmpty && e2.isEmpty) {
      0
    } else if (e1.isEmpty) {
      -1
    } else if (e2.isEmpty) {
      1
    } else {
      val upperComparance = e1.upperLimitObject.compareTo(e2.upperLimitObject)
      val lowerComparance = e1.lowerLimitObject.compareTo(e2.lowerLimitObject)
      if (upperComparance != 0) upperComparance * upperFactor
      else lowerComparance * lowerFactor
    }
}

/** `UpperLowerOrdering`コンパニオンオブジェクト。
  */
object UpperLowerOrdering {

  /** インスタンスを生成する。
    *
    * @param inverseLower
    *   下限が逆順の場合は`true`
    * @param inverseUpper
    *   上限が逆順の場合は`false`
    * @return
    *   [[UpperLowerOrdering]]
    */
  def apply[T](inverseLower: Boolean, inverseUpper: Boolean): UpperLowerOrdering[T] =
    new UpperLowerOrdering[T](inverseLower, inverseUpper)

  /** 抽出子メソッド。
    *
    * @param upperLowerOrdering
    *   [[UpperLowerOrdering]]
    * @return
    *   `Option[(Boolean, Boolean)]`
    */
  def unapply[T](upperLowerOrdering: UpperLowerOrdering[T]): Option[(Boolean, Boolean)] =
    Some(upperLowerOrdering.inverseLower, upperLowerOrdering.inverseUpper)

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy