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

dotty.tools.dotc.printing.MessageLimiter.scala Maven / Gradle / Ivy

package dotty.tools
package dotc
package printing

import core.*
import Contexts.*
import util.Property
import Texts.Text

abstract class MessageLimiter:

  protected def recurseLimit = 100
  protected var recurseCount: Int = 0

  def register(str: String): Unit = ()

  protected def recursionLimitExceeded()(using Context): Unit = ()

  final def controlled(op: => Text)(using Context): Text =
    if recurseCount < recurseLimit then
      try
        recurseCount += 1
        op
      finally
        recurseCount -= 1
    else
      recursionLimitExceeded()
      "..."

object MessageLimiter extends Property.Key[MessageLimiter]

class DefaultMessageLimiter extends MessageLimiter:
  override def recursionLimitExceeded()(using Context): Unit =
    if ctx.debug then
      report.warning("Exceeded recursion depth attempting to print.")
      Thread.dumpStack()

class SummarizeMessageLimiter(depth: Int) extends MessageLimiter:
  override val recurseLimit = recurseCount + depth
  override def recursionLimitExceeded()(using Context): Unit = ()

class ErrorMessageLimiter extends MessageLimiter:
  private val initialRecurseLimit = 50
  private val sizeLimit = 10000

  private var textLength: Int = 0

  override def register(str: String): Unit =
    textLength += str.length

  override def recurseLimit =
    val freeFraction: Double = ((sizeLimit - textLength) max 0).toDouble / sizeLimit
    // 10'000 -     0 / 10'0000 = 100% free
    // 10'000 -   200 / 10'0000 =  98% free * 50 = 49
    // 10'000 - 1'000 / 10'0000 =  90% free * 50 = 45
    // 10'000 - 2'000 / 10'0000 =  80% free * 50 = 40
    // every 200 characters consumes a "recurseCount"
    // which, additionally, is lowered from 100 to 50 here
    (initialRecurseLimit * freeFraction).toInt






© 2015 - 2025 Weber Informatics LLC | Privacy Policy