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

harness.core.NumberOps.scala Maven / Gradle / Ivy

There is a newer version: 5.1.3
Show newest version
package harness.core

private[this] def commaify(str: String): String = {
  def placeCommas(chars: List[Char]): String =
    chars.reverse.grouped(3).toList.reverseMap(_.reverse.mkString).mkString(",")

  str.toList match {
    case '-' :: chars => "-" + placeCommas(chars)
    case chars        => placeCommas(chars)
  }
}

extension (self: Long) {

  def toStringCommas: String =
    commaify(self.toString)

  def pluralizeOn(base: String, pluralSuffix: String = "s", singularSuffix: String = "", addCommas: Boolean = true): String =
    s"${if (addCommas) self.toStringCommas else self.toString} ${base.pluralize(self, pluralSuffix, singularSuffix)}"

}

extension (self: Double) {

  def toStringCommas(showEmptyDecimal: Boolean): String =
    BigDecimal(self).toStringCommas(showEmptyDecimal)

  def roundTo(numPlaces: Int): Double =
    roundTo(Math.pow(10, numPlaces))

  def roundTo(mult: Double): Double =
    (self * mult).round.toDouble / mult

  def floorTo(mult: Double): Double =
    (self * mult).floor / mult

  def ceilTo(mult: Double): Double =
    (self * mult).ceil / mult

}

extension (self: BigDecimal) {

  def toStringCommas(showEmptyDecimal: Boolean): String = {
    def convert(int: String, fract: String): String =
      (commaify(int) :: Option.when(showEmptyDecimal || fract != "0")(fract).toList).mkString(".")

    self.toString.split("\\.") match {
      case Array(int, fract) => convert(int, fract)
      case Array(int)        => convert(int, "0")
      case _                 => ???
    }
  }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy