Skip to content

Commit

Permalink
allow threads to die with ExitSuccess without printing a message
Browse files Browse the repository at this point in the history
  • Loading branch information
mitchellwrosen committed Jan 17, 2025
1 parent 7e7836a commit e4e5b8f
Showing 1 changed file with 28 additions and 19 deletions.
47 changes: 28 additions & 19 deletions unison-cli/src/Unison/Main.hs
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ import ArgParse
)
import Compat (defaultInterruptHandler, withInterruptHandler)
import Control.Concurrent (newEmptyMVar, runInUnboundThread, takeMVar)
import Control.Exception (displayException, evaluate)
import Control.Exception (displayException, evaluate, fromException)
import Data.ByteString.Lazy qualified as BL
import Data.Either.Validation (Validation (..))
import Data.List.NonEmpty (NonEmpty)
Expand All @@ -45,6 +45,7 @@ import System.Directory
removeDirectoryRecursive,
)
import System.Environment (getExecutablePath, getProgName, withArgs)
import System.Exit (ExitCode (..))
import System.Exit qualified as Exit
import System.Exit qualified as System
import System.FilePath
Expand Down Expand Up @@ -110,26 +111,30 @@ main version = do
-- Replace the default exception handler with one complains loudly, because we shouldn't have any uncaught exceptions.
-- Sometimes `show` and `displayException` are different strings; in this case, we want to show them both, so this
-- issue is easier to debug.
--
-- We've made one exception for `ExitSuccess`, because we've discovered the `lsp` library unhelpfully throws it from a
-- background thread as part of the default "exit notification handler", with no way to modify the behavior.
setUncaughtExceptionHandler \exception -> do
let shown = tShow exception
let displayed = Text.pack (displayException exception)
let indented = Text.unlines . map (" " <>) . Text.lines
when (not (isExitSuccess exception)) do
let shown = tShow exception
let displayed = Text.pack (displayException exception)
let indented = Text.unlines . map (" " <>) . Text.lines

Text.hPutStrLn stderr . Text.unlines . fold $
[ [ "Uh oh, an unexpected exception brought the process down! That should never happen. Please file a bug report.",
"",
"Here's a stringy rendering of the exception:",
"",
indented shown
],
if shown /= displayed
then
[ "And here's a different one, in case it's easier to understand:",
"",
indented displayed
]
else []
]
Text.hPutStrLn stderr . Text.unlines . fold $
[ [ "Uh oh, an unexpected exception brought the process down! That should never happen. Please file a bug report.",
"",
"Here's a stringy rendering of the exception:",
"",
indented shown
],
if shown /= displayed
then
[ "And here's a different one, in case it's easier to understand:",
"",
indented displayed
]
else []
]

withCP65001 . runInUnboundThread . Ki.scoped $ \scope -> do
interruptHandler <- defaultInterruptHandler
Expand Down Expand Up @@ -360,6 +365,10 @@ main version = do
-- startNativeRuntime saves the path to `unison-runtime`
=<< RTI.startNativeRuntime (Version.gitDescribeWithDate version) nrtp

isExitSuccess :: SomeException -> Bool
isExitSuccess =
(== Just ExitSuccess) . fromException

-- | Set user agent and configure TLS on global http client.
-- Note that the authorized http client is distinct from the global http client.
initHTTPClient :: Version -> IO ()
Expand Down

0 comments on commit e4e5b8f

Please sign in to comment.