From 8a07d0ecbcb876df6f5ddca8d125f4e6091f1aea Mon Sep 17 00:00:00 2001 From: Lin Jian Date: Tue, 26 Aug 2025 02:42:07 +0800 Subject: [PATCH] Add a context parameter for getSignatureHelp I find it is useful to pass the context when implementing the signature help feature for HLS. --- lsp-test/src/Language/LSP/Test.hs | 6 +++--- lsp-test/test/Test.hs | 2 +- 2 files changed, 4 insertions(+), 4 deletions(-) diff --git a/lsp-test/src/Language/LSP/Test.hs b/lsp-test/src/Language/LSP/Test.hs index b4d7ec92..049a0c15 100644 --- a/lsp-test/src/Language/LSP/Test.hs +++ b/lsp-test/src/Language/LSP/Test.hs @@ -937,9 +937,9 @@ getHover doc pos = in nullToMaybe . getResponseResult <$> request SMethod_TextDocumentHover params -- | Returns the signature help at the specified position. -getSignatureHelp :: TextDocumentIdentifier -> Position -> Session (Maybe SignatureHelp) -getSignatureHelp doc pos = - let params = SignatureHelpParams doc pos Nothing Nothing +getSignatureHelp :: TextDocumentIdentifier -> Position -> Maybe SignatureHelpContext -> Session (Maybe SignatureHelp) +getSignatureHelp doc pos mCtx = + let params = SignatureHelpParams doc pos Nothing mCtx in nullToMaybe . getResponseResult <$> request SMethod_TextDocumentSignatureHelp params -- | Returns the highlighted occurrences of the term at the specified position diff --git a/lsp-test/test/Test.hs b/lsp-test/test/Test.hs index e953a77e..7a18188d 100644 --- a/lsp-test/test/Test.hs +++ b/lsp-test/test/Test.hs @@ -310,7 +310,7 @@ main = hspec $ around withDummyServer $ do describe "getSignatureHelp" $ it "works" $ \(hin, hout) -> runSessionWithHandles hin hout def fullLatestClientCaps "." $ do doc <- openDoc "test/data/renamePass/Desktop/simple.hs" "haskell" - signatureHelp <- getSignatureHelp doc (Position 22 32) + signatureHelp <- getSignatureHelp doc (Position 22 32) Nothing liftIO $ signatureHelp `shouldSatisfy` isJust -- describe "getHighlights" $