src/Pure/General/logger.scala
author wenzelm
Sat, 04 Mar 2023 23:43:53 +0100
changeset 77511 3d6db917bd1b
parent 77286 6435b0fd48b5
child 79767 52b5c7c8e6d9
permissions -rw-r--r--
clarified modules;

/*  Title:      Pure/General/logger.scala
    Author:     Makarius

Minimal logging support.
*/

package isabelle


object Logger {
  def make(log_file: Option[Path]): Logger =
    log_file match { case Some(file) => new File_Logger(file) case None => No_Logger }

  def make(progress: Progress): Logger =
    new Logger { def apply(msg: => String): Unit = progress.echo(msg) }

  def make_system_log(progress: Progress, options: Options): Logger =
    options.string("system_log") match {
      case "" => No_Logger
      case "-" => make(progress)
      case log_file => make(Some(Path.explode(log_file)))
    }
}

trait Logger {
  def apply(msg: => String): Unit

  def timeit[A](body: => A,
    message: Exn.Result[A] => String = null,
    enabled: Boolean = true
  ): A = Timing.timeit(body, message = message, enabled = enabled, output = apply(_))
}

object No_Logger extends Logger {
  def apply(msg: => String): Unit = {}
}

class File_Logger(path: Path) extends Logger {
  def apply(msg: => String): Unit = synchronized { File.append(path, msg + "\n") }

  override def toString: String = path.toString
}

class System_Logger extends Logger {
  def apply(msg: => String): Unit = synchronized {
    if (Platform.is_windows) System.out.println(msg)
    else System.console.writer.println(msg)
  }
}