Skip to content

Commit

Permalink
Log all errors caught in the frontend at debug level
Browse files Browse the repository at this point in the history
  • Loading branch information
mbovel committed Dec 10, 2024
1 parent b8b76f4 commit b8913b1
Showing 1 changed file with 22 additions and 6 deletions.
28 changes: 22 additions & 6 deletions core/src/main/scala/stainless/frontend/ThreadedFrontend.scala
Original file line number Diff line number Diff line change
Expand Up @@ -32,6 +32,20 @@ abstract class ThreadedFrontend(callback: CallBack, ctx: inox.Context) extends F
initRun()
callback.beginExtractions()
onRun()
} catch {
case e: Throwable => {
// `BatchedCallBack.endExtractions` and
// `SplitCallBack.endExtractions` only run if there are no errors
// reported. Not reporting errors here allow them to potentially
// recover from some errors.
//
// Matt: Do we really want that? From which errors can they actually
// recover? There might be non-recoverable exceptions benefiting
// from being reported here already or in handler below, either as
// errors or as warnings. See #1618 for more context.
ctx.reporter.debug("The following exception has been caught in the frontend init or run:")
ctx.reporter.debug(e)
}
} finally {
callback.endExtractions()
onEnd()
Expand All @@ -43,10 +57,13 @@ abstract class ThreadedFrontend(callback: CallBack, ctx: inox.Context) extends F

thread = new Thread(runnable, "stainless frontend")
thread.setUncaughtExceptionHandler(new Thread.UncaughtExceptionHandler() {
override def uncaughtException(t: Thread, e: Throwable): Unit = {
ThreadedFrontend.this.synchronized(exceptions += e)
}
})
override def uncaughtException(t: Thread, e: Throwable): Unit =
this.synchronized {
exceptions += e
}
ctx.reporter.debug("The following exception has been caught in the frontend end:")
ctx.reporter.debug(e)
})

thread.start()
}
Expand All @@ -69,9 +86,8 @@ abstract class ThreadedFrontend(callback: CallBack, ctx: inox.Context) extends F
case UnsupportedCodeException(pos, msg) =>
ctx.reporter.error(pos, msg)
case _ =>
ctx.reporter.debug(s"Rethrowing exception emitted from within the compiler: ${ex.getMessage}")
ctx.reporter.debug(s"Rethrowing the first exception caught in the frontend end: ${ex.getMessage}.")
exceptions.clear()
throw ex
}
}

0 comments on commit b8913b1

Please sign in to comment.