com.fasterxml.jackson.module.scala.introspect.OrderingLocator.scala Maven / Gradle / Ivy
package com.fasterxml.jackson.module.scala.introspect
import com.fasterxml.jackson.databind.JavaType
object OrderingLocator {
val ORDERINGS = Map.apply[Class[_],Ordering[_]](
classOf[Unit] -> Ordering.Unit,
classOf[Boolean] -> Ordering.Boolean,
classOf[Byte] -> Ordering.Byte,
classOf[Char] -> Ordering.Char,
classOf[Short] -> Ordering.Short,
classOf[Int] -> Ordering.Int,
classOf[Long] -> Ordering.Long,
classOf[Float] -> implicitly[Ordering[Float]],
classOf[Double] -> implicitly[Ordering[Double]],
classOf[BigInt] -> Ordering.BigInt,
classOf[BigDecimal] -> Ordering.BigDecimal,
classOf[String] -> Ordering.String
)
def locate[T](javaType: JavaType): Ordering[T] = {
def matches(other: Class[_]) = other.isAssignableFrom(javaType.getRawClass)
val found: Option[Ordering[_]] = ORDERINGS.find(_._1.isAssignableFrom(javaType.getRawClass)).map(_._2)
val ordering =
found.getOrElse {
if (matches(classOf[Option[_]])) {
val delegate = locate[AnyRef](javaType.getContentType)
Ordering.Option(delegate)
}
else if (matches(classOf[Comparable[_]]))
new Ordering[T] {
def compare(x: T, y: T): Int = {
x.asInstanceOf[Comparable[T]].compareTo(y)
}
}
else throw new IllegalArgumentException("Unsupported value type: " + javaType.getRawClass.getCanonicalName)
}
ordering.asInstanceOf[Ordering[T]]
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy