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

scribe.Level.scala Maven / Gradle / Ivy

There is a newer version: 3.15.3
Show newest version
package scribe

case class Level(name: String, value: Double) extends LogFeature {
  def namePadded: String = Level.padded(this)

  Level.add(this)

  override def apply(record: LogRecord): LogRecord = record.copy(level = this, levelValue = value)
}

object Level {
  private var maxLength = 0

  private var map = Map.empty[String, Level]
  private var padded = Map.empty[Level, String]

  implicit final val LevelOrdering: Ordering[Level] = Ordering.by[Level, Double](_.value).reverse

  val Trace: Level = Level("TRACE", 100.0)
  val Debug: Level = Level("DEBUG", 200.0)
  val Info: Level = Level("INFO", 300.0)
  val Warn: Level = Level("WARN", 400.0)
  val Error: Level = Level("ERROR", 500.0)
  val Fatal: Level = Level("FATAL", 600.0)

  def add(level: Level): Unit = synchronized {
    val length = level.name.length
    map += level.name.toLowerCase -> level
    if (length > maxLength) {
      maxLength = length
      padded = map.map {
        case (_, level) => level -> level.name.padTo(maxLength, " ").mkString
      }
    } else {
      padded += level -> level.name.padTo(maxLength, " ").mkString
    }
  }

  def get(name: String): Option[Level] = map.get(name.toLowerCase)

  def apply(name: String): Level = get(name).getOrElse(throw new RuntimeException(s"Level not found by name: $name"))
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy