X-Git-Url: http://git.lukelau.me/?p=lsp-test.git;a=blobdiff_plain;f=src%2FLanguage%2FHaskell%2FLSP%2FTest%2FSession.hs;h=1777f15f2750a913e812df81c7a42d7c6156fee1;hp=ae8ba1e0fbb15917697bd8e2f3589ebcf59a0862;hb=bd2ac7da01645dc111a6912be661bc13b7f9340f;hpb=0f4d99b0d8a4530c395fb76dc4af68aacb4ce0c8 diff --git a/src/Language/Haskell/LSP/Test/Session.hs b/src/Language/Haskell/LSP/Test/Session.hs index ae8ba1e..1777f15 100644 --- a/src/Language/Haskell/LSP/Test/Session.hs +++ b/src/Language/Haskell/LSP/Test/Session.hs @@ -48,7 +48,6 @@ import Data.Conduit as Conduit import Data.Conduit.Parser as Parser import Data.Default import Data.Foldable -import Data.IORef import Data.List import qualified Data.Map as Map import qualified Data.Text as T @@ -191,12 +190,10 @@ runSessionWithHandles :: Handle -- ^ Server in -> SessionConfig -> ClientCapabilities -> FilePath -- ^ Root directory + -> Session () -- ^ To exit Server -> Session a -> IO a -runSessionWithHandles serverIn serverOut serverHandler config caps rootDir session = do - -- We use this IORef to make exception non-fatal when the server is supposed to shutdown. - - exitOk <- newIORef False +runSessionWithHandles serverIn serverOut serverHandler config caps rootDir exitServer session = do absRootDir <- canonicalizePath rootDir @@ -215,15 +212,13 @@ runSessionWithHandles serverIn serverOut serverHandler config caps rootDir sessi let context = SessionContext serverIn absRootDir messageChan reqMap initRsp config caps initState = SessionState (IdInt 0) mempty mempty 0 False Nothing - errorHandler ex = do x <- readIORef exitOk - unless x $ throwTo mainThreadId (ex :: SessionException) - launchServerHandler = forkIO $ catch (serverHandler serverOut context) errorHandler - (result, _) <- bracket - launchServerHandler - (\tid -> do runSession context initState sendExitMessage - killThread tid - atomicWriteIORef exitOk True) - (const $ runSession context initState session) + runSession' = runSession context initState + + errorHandler = throwTo mainThreadId :: SessionException -> IO() + serverLauncher = forkIO $ catch (serverHandler serverOut context) errorHandler + serverFinalizer tid = runSession' exitServer >> killThread tid + + (result, _) <- bracket serverLauncher serverFinalizer (const $ runSession' session) return result updateStateC :: ConduitM FromServerMessage FromServerMessage (StateT SessionState (ReaderT SessionContext IO)) () @@ -310,9 +305,6 @@ sendMessage msg = do logMsg LogClient msg liftIO $ B.hPut h (addHeader $ encode msg) -sendExitMessage :: (MonadIO m, HasReader SessionContext m) => m () -sendExitMessage = sendMessage (NotificationMessage "2.0" Exit ExitParams) - -- | Execute a block f that will throw a 'Timeout' exception -- after duration seconds. This will override the global timeout -- for waiting for messages to arrive defined in 'SessionConfig'.