akka.stream.impl.streamref.StreamRefSettingsImpl.scala Maven / Gradle / Ivy
/*
* Copyright (C) 2018-2020 Lightbend Inc.
*/
package akka.stream.impl.streamref
import akka.annotation.InternalApi
import akka.event.Logging
import akka.stream.StreamRefSettings
import scala.concurrent.duration.FiniteDuration
/** INTERNAL API */
@InternalApi
private[akka] final case class StreamRefSettingsImpl private (
override val bufferCapacity: Int,
override val demandRedeliveryInterval: FiniteDuration,
override val subscriptionTimeout: FiniteDuration,
override val finalTerminationSignalDeadline: FiniteDuration)
extends StreamRefSettings {
override def withBufferCapacity(value: Int): StreamRefSettings = copy(bufferCapacity = value)
override def withDemandRedeliveryInterval(value: FiniteDuration): StreamRefSettings =
copy(demandRedeliveryInterval = value)
override def withSubscriptionTimeout(value: FiniteDuration): StreamRefSettings = copy(subscriptionTimeout = value)
override def withTerminationReceivedBeforeCompletionLeeway(value: FiniteDuration): StreamRefSettings =
copy(finalTerminationSignalDeadline = value)
override def productPrefix: String = Logging.simpleName(classOf[StreamRefSettings])
}