org.apache.pekko.event.LoggerMailbox.scala Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of pekko-actor_2.13 Show documentation
Show all versions of pekko-actor_2.13 Show documentation
Apache Pekko is a toolkit for building highly concurrent, distributed, and resilient message-driven applications for Java and Scala.
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* license agreements; and to You under the Apache License, version 2.0:
*
* https://www.apache.org/licenses/LICENSE-2.0
*
* This file is part of the Apache Pekko project, which was derived from Akka.
*/
/*
* Copyright (C) 2015-2022 Lightbend Inc.
*/
package org.apache.pekko.event
import com.typesafe.config.Config
import org.apache.pekko
import pekko.actor.ActorRef
import pekko.actor.ActorSystem
import pekko.dispatch.MailboxType
import pekko.dispatch.MessageQueue
import pekko.dispatch.ProducesMessageQueue
import pekko.dispatch.UnboundedMailbox
import pekko.event.Logging.LogEvent
import pekko.util.unused
trait LoggerMessageQueueSemantics
/**
* INTERNAL API
*/
private[pekko] class LoggerMailboxType(@unused settings: ActorSystem.Settings, @unused config: Config)
extends MailboxType
with ProducesMessageQueue[LoggerMailbox] {
override def create(owner: Option[ActorRef], system: Option[ActorSystem]) = (owner, system) match {
case (Some(o), Some(s)) => new LoggerMailbox(o, s)
case _ => throw new IllegalArgumentException("no mailbox owner or system given")
}
}
/**
* INTERNAL API
*/
private[pekko] class LoggerMailbox(@unused owner: ActorRef, system: ActorSystem)
extends UnboundedMailbox.MessageQueue
with LoggerMessageQueueSemantics {
override def cleanUp(owner: ActorRef, deadLetters: MessageQueue): Unit = {
if (hasMessages) {
val logLevel = system.eventStream.logLevel
var envelope = dequeue()
// Drain all remaining messages to the StandardOutLogger.
// cleanUp is called after switching out the mailbox, which is why
// this kind of look works without a limit.
val loggingEnabled = Logging.AllLogLevels.contains(logLevel)
while (envelope ne null) {
// skip logging if level is OFF
if (loggingEnabled)
envelope.message match {
case e: LogEvent if e.level <= logLevel =>
// Logging.StandardOutLogger is a MinimalActorRef, i.e. not a "real" actor
Logging.StandardOutLogger.tell(envelope.message, envelope.sender)
case _ => // skip
}
envelope = dequeue()
}
}
super.cleanUp(owner, deadLetters)
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy