X-Git-Url: http://git.lukelau.me/?p=lsp-test.git;a=blobdiff_plain;f=example%2FMain.hs;fp=example%2FMain.hs;h=c992b8ea67390760497b6fdee187078c428489a8;hp=cc74026531ead6183d384d9113fd001a8f60e510;hb=b1b104cd31ca2e90b6c1842be93b61a14d942101;hpb=fbb260c6078a39ff071fefd6586af18715b3e6a3 diff --git a/example/Main.hs b/example/Main.hs index cc74026..c992b8e 100644 --- a/example/Main.hs +++ b/example/Main.hs @@ -1,14 +1,19 @@ -import Language.Haskell.LSP.Test -import Language.Haskell.LSP.TH.DataTypesJSON - +import Control.Applicative.Combinators import Control.Monad.IO.Class +import Language.Haskell.LSP.Test +import Language.Haskell.LSP.Types main = runSession "hie --lsp" "test/recordings/renamePass" $ do docItem <- openDoc "Desktop/simple.hs" "haskell" + -- Use your favourite favourite combinators. + skipManyTill loggingNotification (count 2 publishDiagnosticsNotification) + + -- Send requests and notifications and receive responses let params = DocumentSymbolParams docItem - _ <- sendRequest TextDocumentDocumentSymbol params :: Session DocumentSymbolsResponse + response <- sendRequest TextDocumentDocumentSymbol params :: Session DocumentSymbolsResponse + liftIO $ print response - skipMany loggingNotification + -- Or use one of the helper functions + getDocumentSymbols docItem >>= liftIO . print - anyResponse >>= liftIO . print