{-# LANGUAGE BangPatterns #-}
{-# LANGUAGE FlexibleContexts #-}
{-# LANGUAGE GADTs #-}
{-# LANGUAGE LambdaCase #-}
{-# LANGUAGE NamedFieldPuns #-}
{-# LANGUAGE OverloadedLabels #-}
{-# LANGUAGE OverloadedStrings #-}
{-# LANGUAGE RankNTypes #-}
{-# LANGUAGE RecordWildCards #-}
{-# LANGUAGE RecursiveDo #-}
{-# LANGUAGE ScopedTypeVariables #-}
{-# LANGUAGE StandaloneDeriving #-}
{-# LANGUAGE TypeInType #-}
{-# OPTIONS_GHC -Wno-deprecations #-}
{-# OPTIONS_GHC -Wno-name-shadowing #-}
{-# OPTIONS_GHC -Wno-unticked-promoted-constructors #-}
module Language.LSP.Server.Processing where
import Colog.Core (
LogAction (..),
Severity (..),
WithSeverity (..),
cmap,
(<&),
)
import Control.Concurrent.STM
import Control.Exception qualified as E
import Control.Lens hiding (Empty)
import Control.Monad
import Control.Monad.Except ()
import Control.Monad.IO.Class
import Control.Monad.Reader
import Control.Monad.State
import Control.Monad.Trans.Except
import Control.Monad.Writer.Strict
import Data.Aeson hiding (
Error,
Null,
Options,
)
import Data.Aeson.Lens ()
import Data.Aeson.Types hiding (
Error,
Null,
Options,
)
import Data.ByteString.Lazy qualified as BSL
import Data.Foldable (traverse_)
import Data.Functor.Product qualified as P
import Data.IxMap
import Data.List
import Data.List.NonEmpty (NonEmpty (..))
import Data.Map.Strict qualified as Map
import Data.Maybe
import Data.Monoid
import Data.Row
import Data.String (fromString)
import Data.Text qualified as T
import Data.Text.Lazy.Encoding qualified as TL
import Data.Text.Prettyprint.Doc
import Language.LSP.Protocol.Lens qualified as L
import Language.LSP.Protocol.Message
import Language.LSP.Protocol.Types
import Language.LSP.Protocol.Utils.SMethodMap (SMethodMap)
import Language.LSP.Protocol.Utils.SMethodMap qualified as SMethodMap
import Language.LSP.Server.Core
import Language.LSP.VFS as VFS
import System.Exit
data LspProcessingLog
= VfsLog VfsLog
| LspCore LspCoreLog
| MessageProcessingError BSL.ByteString String
| forall m. MissingHandler Bool (SClientMethod m)
| ProgressCancel ProgressToken
| Exiting
deriving instance Show LspProcessingLog
instance Pretty LspProcessingLog where
pretty :: forall ann. LspProcessingLog -> Doc ann
pretty (VfsLog VfsLog
l) = VfsLog -> Doc ann
forall a ann. Pretty a => a -> Doc ann
forall ann. VfsLog -> Doc ann
pretty VfsLog
l
pretty (LspCore LspCoreLog
l) = LspCoreLog -> Doc ann
forall a ann. Pretty a => a -> Doc ann
forall ann. LspCoreLog -> Doc ann
pretty LspCoreLog
l
pretty (MessageProcessingError ByteString
bs String
err) =
[Doc ann] -> Doc ann
forall ann. [Doc ann] -> Doc ann
vsep
[ Doc ann
"LSP: incoming message parse error:"
, String -> Doc ann
forall ann. String -> Doc ann
forall a ann. Pretty a => a -> Doc ann
pretty String
err
, Doc ann
"when processing"
, Text -> Doc ann
forall ann. Text -> Doc ann
forall a ann. Pretty a => a -> Doc ann
pretty (ByteString -> Text
TL.decodeUtf8 ByteString
bs)
]
pretty (MissingHandler Bool
_ SClientMethod @t m
m) = Doc ann
"LSP: no handler for:" Doc ann -> Doc ann -> Doc ann
forall ann. Doc ann -> Doc ann -> Doc ann
<+> SClientMethod @t m -> Doc ann
forall a ann. Pretty a => a -> Doc ann
forall ann. SClientMethod @t m -> Doc ann
pretty SClientMethod @t m
m
pretty (ProgressCancel ProgressToken
tid) = Doc ann
"LSP: cancelling action for token:" Doc ann -> Doc ann -> Doc ann
forall ann. Doc ann -> Doc ann -> Doc ann
<+> ProgressToken -> Doc ann
forall a ann. Pretty a => a -> Doc ann
forall ann. ProgressToken -> Doc ann
pretty ProgressToken
tid
pretty LspProcessingLog
Exiting = Doc ann
"LSP: Got exit, exiting"
processMessage :: (m ~ LspM config) => LogAction m (WithSeverity LspProcessingLog) -> BSL.ByteString -> m ()
processMessage :: forall (m :: * -> *) config.
((m :: (* -> *)) ~ (LspM config :: (* -> *))) =>
LogAction m (WithSeverity LspProcessingLog) -> ByteString -> m ()
processMessage LogAction m (WithSeverity LspProcessingLog)
logger ByteString
jsonStr = do
TVar ResponseMap
pendingResponsesVar <- ReaderT (LanguageContextEnv config) IO (TVar ResponseMap)
-> LspT config IO (TVar ResponseMap)
forall config (m :: * -> *) a.
ReaderT (LanguageContextEnv config) m a -> LspT config m a
LspT (ReaderT (LanguageContextEnv config) IO (TVar ResponseMap)
-> LspT config IO (TVar ResponseMap))
-> ReaderT (LanguageContextEnv config) IO (TVar ResponseMap)
-> LspT config IO (TVar ResponseMap)
forall a b. (a -> b) -> a -> b
$ (LanguageContextEnv config -> TVar ResponseMap)
-> ReaderT (LanguageContextEnv config) IO (TVar ResponseMap)
forall r (m :: * -> *) a. MonadReader r m => (r -> a) -> m a
asks ((LanguageContextEnv config -> TVar ResponseMap)
-> ReaderT (LanguageContextEnv config) IO (TVar ResponseMap))
-> (LanguageContextEnv config -> TVar ResponseMap)
-> ReaderT (LanguageContextEnv config) IO (TVar ResponseMap)
forall a b. (a -> b) -> a -> b
$ LanguageContextState config -> TVar ResponseMap
forall config. LanguageContextState config -> TVar ResponseMap
resPendingResponses (LanguageContextState config -> TVar ResponseMap)
-> (LanguageContextEnv config -> LanguageContextState config)
-> LanguageContextEnv config
-> TVar ResponseMap
forall b c a. (b -> c) -> (a -> b) -> a -> c
. LanguageContextEnv config -> LanguageContextState config
forall config.
LanguageContextEnv config -> LanguageContextState config
resState
m (m ()) -> m ()
forall (m :: * -> *) a. Monad m => m (m a) -> m a
join (m (m ()) -> m ()) -> m (m ()) -> m ()
forall a b. (a -> b) -> a -> b
$ IO (m ()) -> m (m ())
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO (m ()) -> m (m ())) -> IO (m ()) -> m (m ())
forall a b. (a -> b) -> a -> b
$ STM (m ()) -> IO (m ())
forall a. STM a -> IO a
atomically (STM (m ()) -> IO (m ())) -> STM (m ()) -> IO (m ())
forall a b. (a -> b) -> a -> b
$ (Either String (m ()) -> m ())
-> STM (Either String (m ())) -> STM (m ())
forall a b. (a -> b) -> STM a -> STM b
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap Either String (m ()) -> m ()
handleErrors (STM (Either String (m ())) -> STM (m ()))
-> STM (Either String (m ())) -> STM (m ())
forall a b. (a -> b) -> a -> b
$ ExceptT String STM (m ()) -> STM (Either String (m ()))
forall e (m :: * -> *) a. ExceptT e m a -> m (Either e a)
runExceptT (ExceptT String STM (m ()) -> STM (Either String (m ())))
-> ExceptT String STM (m ()) -> STM (Either String (m ()))
forall a b. (a -> b) -> a -> b
$ do
Value
val <- Either String Value -> ExceptT String STM Value
forall (m :: * -> *) e a. Monad m => Either e a -> ExceptT e m a
except (Either String Value -> ExceptT String STM Value)
-> Either String Value -> ExceptT String STM Value
forall a b. (a -> b) -> a -> b
$ ByteString -> Either String Value
forall a. FromJSON a => ByteString -> Either String a
eitherDecode ByteString
jsonStr
ResponseMap
pending <- STM ResponseMap -> ExceptT String STM ResponseMap
forall (m :: * -> *) a. Monad m => m a -> ExceptT String m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (STM ResponseMap -> ExceptT String STM ResponseMap)
-> STM ResponseMap -> ExceptT String STM ResponseMap
forall a b. (a -> b) -> a -> b
$ TVar ResponseMap -> STM ResponseMap
forall a. TVar a -> STM a
readTVar TVar ResponseMap
pendingResponsesVar
FromClientMessage'
(Product
@(Method 'ServerToClient 'Request)
ServerResponseCallback
(Const @(Method 'ServerToClient 'Request) ResponseMap))
msg <- Either
String
(FromClientMessage'
(Product
@(Method 'ServerToClient 'Request)
ServerResponseCallback
(Const @(Method 'ServerToClient 'Request) ResponseMap)))
-> ExceptT
String
STM
(FromClientMessage'
(Product
@(Method 'ServerToClient 'Request)
ServerResponseCallback
(Const @(Method 'ServerToClient 'Request) ResponseMap)))
forall (m :: * -> *) e a. Monad m => Either e a -> ExceptT e m a
except (Either
String
(FromClientMessage'
(Product
@(Method 'ServerToClient 'Request)
ServerResponseCallback
(Const @(Method 'ServerToClient 'Request) ResponseMap)))
-> ExceptT
String
STM
(FromClientMessage'
(Product
@(Method 'ServerToClient 'Request)
ServerResponseCallback
(Const @(Method 'ServerToClient 'Request) ResponseMap))))
-> Either
String
(FromClientMessage'
(Product
@(Method 'ServerToClient 'Request)
ServerResponseCallback
(Const @(Method 'ServerToClient 'Request) ResponseMap)))
-> ExceptT
String
STM
(FromClientMessage'
(Product
@(Method 'ServerToClient 'Request)
ServerResponseCallback
(Const @(Method 'ServerToClient 'Request) ResponseMap)))
forall a b. (a -> b) -> a -> b
$ (Value
-> Parser
(FromClientMessage'
(Product
@(Method 'ServerToClient 'Request)
ServerResponseCallback
(Const @(Method 'ServerToClient 'Request) ResponseMap))))
-> Value
-> Either
String
(FromClientMessage'
(Product
@(Method 'ServerToClient 'Request)
ServerResponseCallback
(Const @(Method 'ServerToClient 'Request) ResponseMap)))
forall a b. (a -> Parser b) -> a -> Either String b
parseEither (ResponseMap
-> Value
-> Parser
(FromClientMessage'
(Product
@(Method 'ServerToClient 'Request)
ServerResponseCallback
(Const @(Method 'ServerToClient 'Request) ResponseMap)))
parser ResponseMap
pending) Value
val
STM (m ()) -> ExceptT String STM (m ())
forall (m :: * -> *) a. Monad m => m a -> ExceptT String m a
forall (t :: (* -> *) -> * -> *) (m :: * -> *) a.
(MonadTrans t, Monad m) =>
m a -> t m a
lift (STM (m ()) -> ExceptT String STM (m ()))
-> STM (m ()) -> ExceptT String STM (m ())
forall a b. (a -> b) -> a -> b
$ case FromClientMessage'
(Product
@(Method 'ServerToClient 'Request)
ServerResponseCallback
(Const @(Method 'ServerToClient 'Request) ResponseMap))
msg of
FromClientMess SMethod @'ClientToServer @t m
m TMessage @'ClientToServer @t m
mess ->
m () -> STM (m ())
forall a. a -> STM a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (m () -> STM (m ())) -> m () -> STM (m ())
forall a b. (a -> b) -> a -> b
$ LogAction m (WithSeverity LspProcessingLog)
-> SMethod @'ClientToServer @t m
-> TMessage @'ClientToServer @t m
-> m ()
forall {t :: MessageKind} (m :: * -> *) config
(meth :: Method 'ClientToServer t).
((m :: (* -> *)) ~ (LspM config :: (* -> *))) =>
LogAction m (WithSeverity LspProcessingLog)
-> SClientMethod @t meth -> TClientMessage @t meth -> m ()
handle LogAction m (WithSeverity LspProcessingLog)
logger SMethod @'ClientToServer @t m
m TMessage @'ClientToServer @t m
mess
FromClientRsp (P.Pair (ServerResponseCallback Either ResponseError (MessageResult @'ServerToClient @'Request m)
-> IO ()
f) (Const !ResponseMap
newMap)) TResponseMessage @'ServerToClient m
res -> do
TVar ResponseMap -> ResponseMap -> STM ()
forall a. TVar a -> a -> STM ()
writeTVar TVar ResponseMap
pendingResponsesVar ResponseMap
newMap
m () -> STM (m ())
forall a. a -> STM a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (m () -> STM (m ())) -> m () -> STM (m ())
forall a b. (a -> b) -> a -> b
$ IO () -> m ()
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO () -> m ()) -> IO () -> m ()
forall a b. (a -> b) -> a -> b
$ Either ResponseError (MessageResult @'ServerToClient @'Request m)
-> IO ()
f (TResponseMessage @'ServerToClient m
res TResponseMessage @'ServerToClient m
-> Getting
(Either ResponseError (MessageResult @'ServerToClient @'Request m))
(TResponseMessage @'ServerToClient m)
(Either ResponseError (MessageResult @'ServerToClient @'Request m))
-> Either
ResponseError (MessageResult @'ServerToClient @'Request m)
forall s a. s -> Getting a s a -> a
^. Getting
(Either ResponseError (MessageResult @'ServerToClient @'Request m))
(TResponseMessage @'ServerToClient m)
(Either ResponseError (MessageResult @'ServerToClient @'Request m))
forall s a. HasResult s a => Lens' s a
Lens'
(TResponseMessage @'ServerToClient m)
(Either ResponseError (MessageResult @'ServerToClient @'Request m))
L.result)
where
parser :: ResponseMap -> Value -> Parser (FromClientMessage' (P.Product ServerResponseCallback (Const ResponseMap)))
parser :: ResponseMap
-> Value
-> Parser
(FromClientMessage'
(Product
@(Method 'ServerToClient 'Request)
ServerResponseCallback
(Const @(Method 'ServerToClient 'Request) ResponseMap)))
parser ResponseMap
rm = LookupFunc
'ServerToClient
(Product
@(Method 'ServerToClient 'Request)
ServerResponseCallback
(Const @(Method 'ServerToClient 'Request) ResponseMap))
-> Value
-> Parser
(FromClientMessage'
(Product
@(Method 'ServerToClient 'Request)
ServerResponseCallback
(Const @(Method 'ServerToClient 'Request) ResponseMap)))
forall (a :: Method 'ServerToClient 'Request -> *).
LookupFunc 'ServerToClient a
-> Value -> Parser (FromClientMessage' a)
parseClientMessage (LookupFunc
'ServerToClient
(Product
@(Method 'ServerToClient 'Request)
ServerResponseCallback
(Const @(Method 'ServerToClient 'Request) ResponseMap))
-> Value
-> Parser
(FromClientMessage'
(Product
@(Method 'ServerToClient 'Request)
ServerResponseCallback
(Const @(Method 'ServerToClient 'Request) ResponseMap))))
-> LookupFunc
'ServerToClient
(Product
@(Method 'ServerToClient 'Request)
ServerResponseCallback
(Const @(Method 'ServerToClient 'Request) ResponseMap))
-> Value
-> Parser
(FromClientMessage'
(Product
@(Method 'ServerToClient 'Request)
ServerResponseCallback
(Const @(Method 'ServerToClient 'Request) ResponseMap)))
forall a b. (a -> b) -> a -> b
$ \LspId @'ServerToClient m
i ->
let (Maybe
(Product
@(Method 'ServerToClient 'Request)
(SMethod @'ServerToClient @'Request)
ServerResponseCallback
m)
mhandler, ResponseMap
newMap) = LspId @'ServerToClient m
-> ResponseMap
-> (Maybe
(Product
@(Method 'ServerToClient 'Request)
(SMethod @'ServerToClient @'Request)
ServerResponseCallback
m),
ResponseMap)
forall {a} (k :: a -> *) (m :: a) (f :: a -> *).
IxOrd @a k =>
k m -> IxMap @a k f -> (Maybe (f m), IxMap @a k f)
pickFromIxMap LspId @'ServerToClient m
i ResponseMap
rm
in (\(P.Pair SMethod @'ServerToClient @'Request m
m ServerResponseCallback m
handler) -> (SMethod @'ServerToClient @'Request m
m, ServerResponseCallback m
-> Const @(Method 'ServerToClient 'Request) ResponseMap m
-> Product
@(Method 'ServerToClient 'Request)
ServerResponseCallback
(Const @(Method 'ServerToClient 'Request) ResponseMap)
m
forall {k} (f :: k -> *) (g :: k -> *) (a :: k).
f a -> g a -> Product @k f g a
P.Pair ServerResponseCallback m
handler (ResponseMap
-> Const @(Method 'ServerToClient 'Request) ResponseMap m
forall {k} a (b :: k). a -> Const @k a b
Const ResponseMap
newMap))) (Product
@(Method 'ServerToClient 'Request)
(SMethod @'ServerToClient @'Request)
ServerResponseCallback
m
-> (SMethod @'ServerToClient @'Request m,
Product
@(Method 'ServerToClient 'Request)
ServerResponseCallback
(Const @(Method 'ServerToClient 'Request) ResponseMap)
m))
-> Maybe
(Product
@(Method 'ServerToClient 'Request)
(SMethod @'ServerToClient @'Request)
ServerResponseCallback
m)
-> Maybe
(SMethod @'ServerToClient @'Request m,
Product
@(Method 'ServerToClient 'Request)
ServerResponseCallback
(Const @(Method 'ServerToClient 'Request) ResponseMap)
m)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Maybe
(Product
@(Method 'ServerToClient 'Request)
(SMethod @'ServerToClient @'Request)
ServerResponseCallback
m)
mhandler
handleErrors :: Either String (m ()) -> m ()
handleErrors = (String -> m ()) -> (m () -> m ()) -> Either String (m ()) -> m ()
forall a c b. (a -> c) -> (b -> c) -> Either a b -> c
either (\String
e -> LogAction m (WithSeverity LspProcessingLog)
logger LogAction m (WithSeverity LspProcessingLog)
-> WithSeverity LspProcessingLog -> m ()
forall (m :: * -> *) msg. LogAction m msg -> msg -> m ()
<& ByteString -> String -> LspProcessingLog
MessageProcessingError ByteString
jsonStr String
e LspProcessingLog -> Severity -> WithSeverity LspProcessingLog
forall msg. msg -> Severity -> WithSeverity msg
`WithSeverity` Severity
Error) m () -> m ()
forall a. a -> a
id
initializeRequestHandler ::
LogAction IO (WithSeverity LspProcessingLog) ->
ServerDefinition config ->
VFS ->
(FromServerMessage -> IO ()) ->
TMessage Method_Initialize ->
IO (Maybe (LanguageContextEnv config))
initializeRequestHandler :: forall config.
LogAction IO (WithSeverity LspProcessingLog)
-> ServerDefinition config
-> VFS
-> (FromServerMessage -> IO ())
-> TMessage @'ClientToServer @'Request 'Method_Initialize
-> IO (Maybe (LanguageContextEnv config))
initializeRequestHandler LogAction IO (WithSeverity LspProcessingLog)
logger ServerDefinition{config
Text
Options
config -> m ()
config -> Value -> Either Text config
a -> (<~>) @(*) m IO
ClientCapabilities -> Handlers m
LanguageContextEnv config
-> TMessage @'ClientToServer @'Request 'Method_Initialize
-> IO (Either ResponseError a)
defaultConfig :: config
configSection :: Text
parseConfig :: config -> Value -> Either Text config
onConfigChange :: config -> m ()
doInitialize :: LanguageContextEnv config
-> TMessage @'ClientToServer @'Request 'Method_Initialize
-> IO (Either ResponseError a)
staticHandlers :: ClientCapabilities -> Handlers m
interpretHandler :: a -> (<~>) @(*) m IO
options :: Options
defaultConfig :: forall config. ServerDefinition config -> config
configSection :: forall config. ServerDefinition config -> Text
parseConfig :: forall config.
ServerDefinition config -> config -> Value -> Either Text config
onConfigChange :: ()
doInitialize :: ()
staticHandlers :: ()
interpretHandler :: ()
options :: forall config. ServerDefinition config -> Options
..} VFS
vfs FromServerMessage -> IO ()
sendFunc TMessage @'ClientToServer @'Request 'Method_Initialize
req = do
let sendResp :: TResponseMessage @'ClientToServer 'Method_Initialize -> IO ()
sendResp = FromServerMessage -> IO ()
sendFunc (FromServerMessage -> IO ())
-> (TResponseMessage @'ClientToServer 'Method_Initialize
-> FromServerMessage)
-> TResponseMessage @'ClientToServer 'Method_Initialize
-> IO ()
forall b c a. (b -> c) -> (a -> b) -> a -> c
. SMethod @'ClientToServer @'Request 'Method_Initialize
-> TResponseMessage @'ClientToServer 'Method_Initialize
-> FromServerMessage
forall (m :: Method 'ClientToServer 'Request)
(a :: Method 'ClientToServer 'Request -> *).
a m -> TResponseMessage @'ClientToServer m -> FromServerMessage' a
FromServerRsp SMethod @'ClientToServer @'Request 'Method_Initialize
SMethod_Initialize
handleErr :: Either ResponseError (LanguageContextEnv config)
-> IO (Maybe (LanguageContextEnv config))
handleErr (Left ResponseError
err) = do
TResponseMessage @'ClientToServer 'Method_Initialize -> IO ()
sendResp (TResponseMessage @'ClientToServer 'Method_Initialize -> IO ())
-> TResponseMessage @'ClientToServer 'Method_Initialize -> IO ()
forall a b. (a -> b) -> a -> b
$ LspId @'ClientToServer 'Method_Initialize
-> ResponseError
-> TResponseMessage @'ClientToServer 'Method_Initialize
forall {f :: MessageDirection} {m :: Method f 'Request}.
LspId @f m -> ResponseError -> TResponseMessage @f m
makeResponseError (TMessage @'ClientToServer @'Request 'Method_Initialize
TRequestMessage @'ClientToServer 'Method_Initialize
req TRequestMessage @'ClientToServer 'Method_Initialize
-> Getting
(LspId @'ClientToServer 'Method_Initialize)
(TRequestMessage @'ClientToServer 'Method_Initialize)
(LspId @'ClientToServer 'Method_Initialize)
-> LspId @'ClientToServer 'Method_Initialize
forall s a. s -> Getting a s a -> a
^. Getting
(LspId @'ClientToServer 'Method_Initialize)
(TRequestMessage @'ClientToServer 'Method_Initialize)
(LspId @'ClientToServer 'Method_Initialize)
forall s a. HasId s a => Lens' s a
Lens'
(TRequestMessage @'ClientToServer 'Method_Initialize)
(LspId @'ClientToServer 'Method_Initialize)
L.id) ResponseError
err
Maybe (LanguageContextEnv config)
-> IO (Maybe (LanguageContextEnv config))
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure Maybe (LanguageContextEnv config)
forall a. Maybe a
Nothing
handleErr (Right LanguageContextEnv config
a) = Maybe (LanguageContextEnv config)
-> IO (Maybe (LanguageContextEnv config))
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure (Maybe (LanguageContextEnv config)
-> IO (Maybe (LanguageContextEnv config)))
-> Maybe (LanguageContextEnv config)
-> IO (Maybe (LanguageContextEnv config))
forall a b. (a -> b) -> a -> b
$ LanguageContextEnv config -> Maybe (LanguageContextEnv config)
forall a. a -> Maybe a
Just LanguageContextEnv config
a
(IO (Maybe (LanguageContextEnv config))
-> (SomeException -> IO (Maybe (LanguageContextEnv config)))
-> IO (Maybe (LanguageContextEnv config)))
-> (SomeException -> IO (Maybe (LanguageContextEnv config)))
-> IO (Maybe (LanguageContextEnv config))
-> IO (Maybe (LanguageContextEnv config))
forall a b c. (a -> b -> c) -> b -> a -> c
flip IO (Maybe (LanguageContextEnv config))
-> (SomeException -> IO (Maybe (LanguageContextEnv config)))
-> IO (Maybe (LanguageContextEnv config))
forall e a. Exception e => IO a -> (e -> IO a) -> IO a
E.catch ((ResponseError -> IO ())
-> SomeException -> IO (Maybe (LanguageContextEnv config))
forall a. (ResponseError -> IO ()) -> SomeException -> IO (Maybe a)
initializeErrorHandler ((ResponseError -> IO ())
-> SomeException -> IO (Maybe (LanguageContextEnv config)))
-> (ResponseError -> IO ())
-> SomeException
-> IO (Maybe (LanguageContextEnv config))
forall a b. (a -> b) -> a -> b
$ TResponseMessage @'ClientToServer 'Method_Initialize -> IO ()
sendResp (TResponseMessage @'ClientToServer 'Method_Initialize -> IO ())
-> (ResponseError
-> TResponseMessage @'ClientToServer 'Method_Initialize)
-> ResponseError
-> IO ()
forall b c a. (b -> c) -> (a -> b) -> a -> c
. LspId @'ClientToServer 'Method_Initialize
-> ResponseError
-> TResponseMessage @'ClientToServer 'Method_Initialize
forall {f :: MessageDirection} {m :: Method f 'Request}.
LspId @f m -> ResponseError -> TResponseMessage @f m
makeResponseError (TMessage @'ClientToServer @'Request 'Method_Initialize
TRequestMessage @'ClientToServer 'Method_Initialize
req TRequestMessage @'ClientToServer 'Method_Initialize
-> Getting
(LspId @'ClientToServer 'Method_Initialize)
(TRequestMessage @'ClientToServer 'Method_Initialize)
(LspId @'ClientToServer 'Method_Initialize)
-> LspId @'ClientToServer 'Method_Initialize
forall s a. s -> Getting a s a -> a
^. Getting
(LspId @'ClientToServer 'Method_Initialize)
(TRequestMessage @'ClientToServer 'Method_Initialize)
(LspId @'ClientToServer 'Method_Initialize)
forall s a. HasId s a => Lens' s a
Lens'
(TRequestMessage @'ClientToServer 'Method_Initialize)
(LspId @'ClientToServer 'Method_Initialize)
L.id)) (IO (Maybe (LanguageContextEnv config))
-> IO (Maybe (LanguageContextEnv config)))
-> IO (Maybe (LanguageContextEnv config))
-> IO (Maybe (LanguageContextEnv config))
forall a b. (a -> b) -> a -> b
$ Either ResponseError (LanguageContextEnv config)
-> IO (Maybe (LanguageContextEnv config))
handleErr (Either ResponseError (LanguageContextEnv config)
-> IO (Maybe (LanguageContextEnv config)))
-> (ExceptT ResponseError IO (LanguageContextEnv config)
-> IO (Either ResponseError (LanguageContextEnv config)))
-> ExceptT ResponseError IO (LanguageContextEnv config)
-> IO (Maybe (LanguageContextEnv config))
forall (m :: * -> *) b c a.
Monad m =>
(b -> m c) -> (a -> m b) -> a -> m c
<=< ExceptT ResponseError IO (LanguageContextEnv config)
-> IO (Either ResponseError (LanguageContextEnv config))
forall e (m :: * -> *) a. ExceptT e m a -> m (Either e a)
runExceptT (ExceptT ResponseError IO (LanguageContextEnv config)
-> IO (Maybe (LanguageContextEnv config)))
-> ExceptT ResponseError IO (LanguageContextEnv config)
-> IO (Maybe (LanguageContextEnv config))
forall a b. (a -> b) -> a -> b
$ mdo
let p :: InitializeParams
p = TMessage @'ClientToServer @'Request 'Method_Initialize
TRequestMessage @'ClientToServer 'Method_Initialize
req TRequestMessage @'ClientToServer 'Method_Initialize
-> Getting
InitializeParams
(TRequestMessage @'ClientToServer 'Method_Initialize)
InitializeParams
-> InitializeParams
forall s a. s -> Getting a s a -> a
^. Getting
InitializeParams
(TRequestMessage @'ClientToServer 'Method_Initialize)
InitializeParams
forall s a. HasParams s a => Lens' s a
Lens'
(TRequestMessage @'ClientToServer 'Method_Initialize)
InitializeParams
L.params
rootDir :: Maybe String
rootDir =
First String -> Maybe String
forall a. First a -> Maybe a
getFirst (First String -> Maybe String) -> First String -> Maybe String
forall a b. (a -> b) -> a -> b
$
(Maybe String -> First String) -> [Maybe String] -> First String
forall m a. Monoid m => (a -> m) -> [a] -> m
forall (t :: * -> *) m a.
(Foldable t, Monoid m) =>
(a -> m) -> t a -> m
foldMap
Maybe String -> First String
forall a. Maybe a -> First a
First
[ InitializeParams
p InitializeParams
-> Getting (First Uri) InitializeParams Uri -> Maybe Uri
forall s a. s -> Getting (First a) s a -> Maybe a
^? ((Uri |? Null) -> Const @(*) (First Uri) (Uri |? Null))
-> InitializeParams -> Const @(*) (First Uri) InitializeParams
forall s a. HasRootUri s a => Lens' s a
Lens' InitializeParams (Uri |? Null)
L.rootUri (((Uri |? Null) -> Const @(*) (First Uri) (Uri |? Null))
-> InitializeParams -> Const @(*) (First Uri) InitializeParams)
-> ((Uri -> Const @(*) (First Uri) Uri)
-> (Uri |? Null) -> Const @(*) (First Uri) (Uri |? Null))
-> Getting (First Uri) InitializeParams Uri
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (Uri -> Const @(*) (First Uri) Uri)
-> (Uri |? Null) -> Const @(*) (First Uri) (Uri |? Null)
forall a b (p :: * -> * -> *) (f :: * -> *).
(Choice p, Applicative f) =>
p a (f a) -> p (a |? b) (f (a |? b))
_L Maybe Uri -> (Uri -> Maybe String) -> Maybe String
forall a b. Maybe a -> (a -> Maybe b) -> Maybe b
forall (m :: * -> *) a b. Monad m => m a -> (a -> m b) -> m b
>>= Uri -> Maybe String
uriToFilePath
, InitializeParams
p InitializeParams
-> Getting (First Text) InitializeParams Text -> Maybe Text
forall s a. s -> Getting (First a) s a -> Maybe a
^? (Maybe (Text |? Null)
-> Const @(*) (First Text) (Maybe (Text |? Null)))
-> InitializeParams -> Const @(*) (First Text) InitializeParams
forall s a. HasRootPath s a => Lens' s a
Lens' InitializeParams (Maybe (Text |? Null))
L.rootPath ((Maybe (Text |? Null)
-> Const @(*) (First Text) (Maybe (Text |? Null)))
-> InitializeParams -> Const @(*) (First Text) InitializeParams)
-> ((Text -> Const @(*) (First Text) Text)
-> Maybe (Text |? Null)
-> Const @(*) (First Text) (Maybe (Text |? Null)))
-> Getting (First Text) InitializeParams Text
forall b c a. (b -> c) -> (a -> b) -> a -> c
. ((Text |? Null) -> Const @(*) (First Text) (Text |? Null))
-> Maybe (Text |? Null)
-> Const @(*) (First Text) (Maybe (Text |? Null))
forall a b (p :: * -> * -> *) (f :: * -> *).
(Choice p, Applicative f) =>
p a (f b) -> p (Maybe a) (f (Maybe b))
_Just (((Text |? Null) -> Const @(*) (First Text) (Text |? Null))
-> Maybe (Text |? Null)
-> Const @(*) (First Text) (Maybe (Text |? Null)))
-> ((Text -> Const @(*) (First Text) Text)
-> (Text |? Null) -> Const @(*) (First Text) (Text |? Null))
-> (Text -> Const @(*) (First Text) Text)
-> Maybe (Text |? Null)
-> Const @(*) (First Text) (Maybe (Text |? Null))
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (Text -> Const @(*) (First Text) Text)
-> (Text |? Null) -> Const @(*) (First Text) (Text |? Null)
forall a b (p :: * -> * -> *) (f :: * -> *).
(Choice p, Applicative f) =>
p a (f a) -> p (a |? b) (f (a |? b))
_L Maybe Text -> (Text -> String) -> Maybe String
forall (f :: * -> *) a b. Functor f => f a -> (a -> b) -> f b
<&> Text -> String
T.unpack
]
clientCaps :: ClientCapabilities
clientCaps = (InitializeParams
p InitializeParams
-> Getting ClientCapabilities InitializeParams ClientCapabilities
-> ClientCapabilities
forall s a. s -> Getting a s a -> a
^. Getting ClientCapabilities InitializeParams ClientCapabilities
forall s a. HasCapabilities s a => Lens' s a
Lens' InitializeParams ClientCapabilities
L.capabilities)
let initialWfs :: [WorkspaceFolder]
initialWfs = case InitializeParams
p InitializeParams
-> Getting
(Maybe ([WorkspaceFolder] |? Null))
InitializeParams
(Maybe ([WorkspaceFolder] |? Null))
-> Maybe ([WorkspaceFolder] |? Null)
forall s a. s -> Getting a s a -> a
^. Getting
(Maybe ([WorkspaceFolder] |? Null))
InitializeParams
(Maybe ([WorkspaceFolder] |? Null))
forall s a. HasWorkspaceFolders s a => Lens' s a
Lens' InitializeParams (Maybe ([WorkspaceFolder] |? Null))
L.workspaceFolders of
Just (InL [WorkspaceFolder]
xs) -> [WorkspaceFolder]
xs
Maybe ([WorkspaceFolder] |? Null)
_ -> []
configObject :: Maybe Value
configObject = Text -> Value -> Value
lookForConfigSection Text
configSection (Value -> Value) -> Maybe Value -> Maybe Value
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> (InitializeParams
p InitializeParams
-> Getting (Maybe Value) InitializeParams (Maybe Value)
-> Maybe Value
forall s a. s -> Getting a s a -> a
^. Getting (Maybe Value) InitializeParams (Maybe Value)
forall s a. HasInitializationOptions s a => Lens' s a
Lens' InitializeParams (Maybe Value)
L.initializationOptions)
config
initialConfig <- case Maybe Value
configObject of
Just Value
o -> case config -> Value -> Either Text config
parseConfig config
defaultConfig Value
o of
Right config
newConfig -> do
IO () -> ExceptT ResponseError IO ()
forall a. IO a -> ExceptT ResponseError IO a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO () -> ExceptT ResponseError IO ())
-> IO () -> ExceptT ResponseError IO ()
forall a b. (a -> b) -> a -> b
$ LogAction IO (WithSeverity LspProcessingLog)
logger LogAction IO (WithSeverity LspProcessingLog)
-> WithSeverity LspProcessingLog -> IO ()
forall (m :: * -> *) msg. LogAction m msg -> msg -> m ()
<& (LspCoreLog -> LspProcessingLog
LspCore (LspCoreLog -> LspProcessingLog) -> LspCoreLog -> LspProcessingLog
forall a b. (a -> b) -> a -> b
$ Value -> LspCoreLog
NewConfig Value
o) LspProcessingLog -> Severity -> WithSeverity LspProcessingLog
forall msg. msg -> Severity -> WithSeverity msg
`WithSeverity` Severity
Debug
config -> ExceptT ResponseError IO config
forall a. a -> ExceptT ResponseError IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure config
newConfig
Left Text
err -> do
IO () -> ExceptT ResponseError IO ()
forall a. IO a -> ExceptT ResponseError IO a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO () -> ExceptT ResponseError IO ())
-> IO () -> ExceptT ResponseError IO ()
forall a b. (a -> b) -> a -> b
$ LogAction IO (WithSeverity LspProcessingLog)
logger LogAction IO (WithSeverity LspProcessingLog)
-> WithSeverity LspProcessingLog -> IO ()
forall (m :: * -> *) msg. LogAction m msg -> msg -> m ()
<& (LspCoreLog -> LspProcessingLog
LspCore (LspCoreLog -> LspProcessingLog) -> LspCoreLog -> LspProcessingLog
forall a b. (a -> b) -> a -> b
$ Value -> Text -> LspCoreLog
ConfigurationParseError Value
o Text
err) LspProcessingLog -> Severity -> WithSeverity LspProcessingLog
forall msg. msg -> Severity -> WithSeverity msg
`WithSeverity` Severity
Warning
config -> ExceptT ResponseError IO config
forall a. a -> ExceptT ResponseError IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure config
defaultConfig
Maybe Value
Nothing -> config -> ExceptT ResponseError IO config
forall a. a -> ExceptT ResponseError IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure config
defaultConfig
LanguageContextState config
stateVars <- IO (LanguageContextState config)
-> ExceptT ResponseError IO (LanguageContextState config)
forall a. IO a -> ExceptT ResponseError IO a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO (LanguageContextState config)
-> ExceptT ResponseError IO (LanguageContextState config))
-> IO (LanguageContextState config)
-> ExceptT ResponseError IO (LanguageContextState config)
forall a b. (a -> b) -> a -> b
$ do
TVar VFSData
resVFS <- VFSData -> IO (TVar VFSData)
forall a. a -> IO (TVar a)
newTVarIO (VFS -> Map String String -> VFSData
VFSData VFS
vfs Map String String
forall a. Monoid a => a
mempty)
TVar DiagnosticStore
resDiagnostics <- DiagnosticStore -> IO (TVar DiagnosticStore)
forall a. a -> IO (TVar a)
newTVarIO DiagnosticStore
forall a. Monoid a => a
mempty
TVar config
resConfig <- config -> IO (TVar config)
forall a. a -> IO (TVar a)
newTVarIO config
initialConfig
TVar [WorkspaceFolder]
resWorkspaceFolders <- [WorkspaceFolder] -> IO (TVar [WorkspaceFolder])
forall a. a -> IO (TVar a)
newTVarIO [WorkspaceFolder]
initialWfs
ProgressData
resProgressData <- do
TVar Int32
progressNextId <- Int32 -> IO (TVar Int32)
forall a. a -> IO (TVar a)
newTVarIO Int32
0
TVar (Map ProgressToken (IO ()))
progressCancel <- Map ProgressToken (IO ()) -> IO (TVar (Map ProgressToken (IO ())))
forall a. a -> IO (TVar a)
newTVarIO Map ProgressToken (IO ())
forall a. Monoid a => a
mempty
ProgressData -> IO ProgressData
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure ProgressData{TVar Int32
TVar (Map ProgressToken (IO ()))
progressNextId :: TVar Int32
progressCancel :: TVar (Map ProgressToken (IO ()))
progressNextId :: TVar Int32
progressCancel :: TVar (Map ProgressToken (IO ()))
..}
TVar ResponseMap
resPendingResponses <- ResponseMap -> IO (TVar ResponseMap)
forall a. a -> IO (TVar a)
newTVarIO ResponseMap
forall {a} (k :: a -> *) (f :: a -> *). IxMap @a k f
emptyIxMap
TVar (RegistrationMap 'Notification)
resRegistrationsNot <- RegistrationMap 'Notification
-> IO (TVar (RegistrationMap 'Notification))
forall a. a -> IO (TVar a)
newTVarIO RegistrationMap 'Notification
forall a. Monoid a => a
mempty
TVar (RegistrationMap 'Request)
resRegistrationsReq <- RegistrationMap 'Request -> IO (TVar (RegistrationMap 'Request))
forall a. a -> IO (TVar a)
newTVarIO RegistrationMap 'Request
forall a. Monoid a => a
mempty
TVar Int32
resLspId <- Int32 -> IO (TVar Int32)
forall a. a -> IO (TVar a)
newTVarIO Int32
0
LanguageContextState config -> IO (LanguageContextState config)
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure LanguageContextState{TVar config
TVar Int32
TVar [WorkspaceFolder]
TVar DiagnosticStore
TVar ResponseMap
TVar (RegistrationMap 'Notification)
TVar (RegistrationMap 'Request)
TVar VFSData
ProgressData
resPendingResponses :: TVar ResponseMap
resVFS :: TVar VFSData
resDiagnostics :: TVar DiagnosticStore
resConfig :: TVar config
resWorkspaceFolders :: TVar [WorkspaceFolder]
resProgressData :: ProgressData
resPendingResponses :: TVar ResponseMap
resRegistrationsNot :: TVar (RegistrationMap 'Notification)
resRegistrationsReq :: TVar (RegistrationMap 'Request)
resLspId :: TVar Int32
resVFS :: TVar VFSData
resDiagnostics :: TVar DiagnosticStore
resConfig :: TVar config
resWorkspaceFolders :: TVar [WorkspaceFolder]
resProgressData :: ProgressData
resRegistrationsNot :: TVar (RegistrationMap 'Notification)
resRegistrationsReq :: TVar (RegistrationMap 'Request)
resLspId :: TVar Int32
..}
let env :: LanguageContextEnv config
env = Handlers IO
-> Text
-> (config -> Value -> Either Text config)
-> (config -> IO ())
-> (FromServerMessage -> IO ())
-> LanguageContextState config
-> ClientCapabilities
-> Maybe String
-> LanguageContextEnv config
forall config.
Handlers IO
-> Text
-> (config -> Value -> Either Text config)
-> (config -> IO ())
-> (FromServerMessage -> IO ())
-> LanguageContextState config
-> ClientCapabilities
-> Maybe String
-> LanguageContextEnv config
LanguageContextEnv Handlers IO
handlers Text
configSection config -> Value -> Either Text config
parseConfig config -> IO ()
configChanger FromServerMessage -> IO ()
sendFunc LanguageContextState config
stateVars (InitializeParams
p InitializeParams
-> Getting ClientCapabilities InitializeParams ClientCapabilities
-> ClientCapabilities
forall s a. s -> Getting a s a -> a
^. Getting ClientCapabilities InitializeParams ClientCapabilities
forall s a. HasCapabilities s a => Lens' s a
Lens' InitializeParams ClientCapabilities
L.capabilities) Maybe String
rootDir
configChanger :: config -> IO ()
configChanger config
config = (<~>) @(*) m IO -> forall a. m a -> IO a
forall {k} (m :: k -> *) (n :: k -> *).
(<~>) @k m n -> forall (a :: k). m a -> n a
forward (<~>) @(*) m IO
interpreter (config -> m ()
onConfigChange config
config)
handlers :: Handlers IO
handlers = (<~>) @(*) m IO -> Handlers m -> Handlers IO
forall (m :: * -> *) (n :: * -> *).
(<~>) @(*) m n -> Handlers m -> Handlers n
transmuteHandlers (<~>) @(*) m IO
interpreter (ClientCapabilities -> Handlers m
staticHandlers ClientCapabilities
clientCaps)
interpreter :: (<~>) @(*) m IO
interpreter = a -> (<~>) @(*) m IO
interpretHandler a
initializationResult
a
initializationResult <- IO (Either ResponseError a) -> ExceptT ResponseError IO a
forall e (m :: * -> *) a. m (Either e a) -> ExceptT e m a
ExceptT (IO (Either ResponseError a) -> ExceptT ResponseError IO a)
-> IO (Either ResponseError a) -> ExceptT ResponseError IO a
forall a b. (a -> b) -> a -> b
$ LanguageContextEnv config
-> TMessage @'ClientToServer @'Request 'Method_Initialize
-> IO (Either ResponseError a)
doInitialize LanguageContextEnv config
env TMessage @'ClientToServer @'Request 'Method_Initialize
req
let serverCaps :: ServerCapabilities
serverCaps = ClientCapabilities -> Options -> Handlers IO -> ServerCapabilities
forall (m :: * -> *).
ClientCapabilities -> Options -> Handlers m -> ServerCapabilities
inferServerCapabilities ClientCapabilities
clientCaps Options
options Handlers IO
handlers
IO () -> ExceptT ResponseError IO ()
forall a. IO a -> ExceptT ResponseError IO a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO () -> ExceptT ResponseError IO ())
-> IO () -> ExceptT ResponseError IO ()
forall a b. (a -> b) -> a -> b
$ TResponseMessage @'ClientToServer 'Method_Initialize -> IO ()
sendResp (TResponseMessage @'ClientToServer 'Method_Initialize -> IO ())
-> TResponseMessage @'ClientToServer 'Method_Initialize -> IO ()
forall a b. (a -> b) -> a -> b
$ LspId @'ClientToServer 'Method_Initialize
-> MessageResult @'ClientToServer @'Request 'Method_Initialize
-> TResponseMessage @'ClientToServer 'Method_Initialize
forall {f :: MessageDirection} {m :: Method f 'Request}.
LspId @f m -> MessageResult @f @'Request m -> TResponseMessage @f m
makeResponseMessage (TMessage @'ClientToServer @'Request 'Method_Initialize
TRequestMessage @'ClientToServer 'Method_Initialize
req TRequestMessage @'ClientToServer 'Method_Initialize
-> Getting
(LspId @'ClientToServer 'Method_Initialize)
(TRequestMessage @'ClientToServer 'Method_Initialize)
(LspId @'ClientToServer 'Method_Initialize)
-> LspId @'ClientToServer 'Method_Initialize
forall s a. s -> Getting a s a -> a
^. Getting
(LspId @'ClientToServer 'Method_Initialize)
(TRequestMessage @'ClientToServer 'Method_Initialize)
(LspId @'ClientToServer 'Method_Initialize)
forall s a. HasId s a => Lens' s a
Lens'
(TRequestMessage @'ClientToServer 'Method_Initialize)
(LspId @'ClientToServer 'Method_Initialize)
L.id) (ServerCapabilities
-> Maybe
(Rec
((.+)
@(*)
((.==) @(*) "name" Text)
((.+) @(*) ((.==) @(*) "version" (Maybe Text)) (Empty @(*)))))
-> InitializeResult
InitializeResult ServerCapabilities
serverCaps (Options
-> Maybe
(Rec
((.+)
@(*) ((.==) @(*) "name" Text) ((.==) @(*) "version" (Maybe Text))))
optServerInfo Options
options))
LanguageContextEnv config
-> ExceptT ResponseError IO (LanguageContextEnv config)
forall a. a -> ExceptT ResponseError IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure LanguageContextEnv config
env
where
makeResponseMessage :: LspId @f m -> MessageResult @f @'Request m -> TResponseMessage @f m
makeResponseMessage LspId @f m
rid MessageResult @f @'Request m
result = Text
-> Maybe (LspId @f m)
-> Either ResponseError (MessageResult @f @'Request m)
-> TResponseMessage @f m
forall (f :: MessageDirection) (m :: Method f 'Request).
Text
-> Maybe (LspId @f m)
-> Either ResponseError (MessageResult @f @'Request m)
-> TResponseMessage @f m
TResponseMessage Text
"2.0" (LspId @f m -> Maybe (LspId @f m)
forall a. a -> Maybe a
Just LspId @f m
rid) (MessageResult @f @'Request m
-> Either ResponseError (MessageResult @f @'Request m)
forall a b. b -> Either a b
Right MessageResult @f @'Request m
result)
makeResponseError :: LspId @f m -> ResponseError -> TResponseMessage @f m
makeResponseError LspId @f m
origId ResponseError
err = Text
-> Maybe (LspId @f m)
-> Either ResponseError (MessageResult @f @'Request m)
-> TResponseMessage @f m
forall (f :: MessageDirection) (m :: Method f 'Request).
Text
-> Maybe (LspId @f m)
-> Either ResponseError (MessageResult @f @'Request m)
-> TResponseMessage @f m
TResponseMessage Text
"2.0" (LspId @f m -> Maybe (LspId @f m)
forall a. a -> Maybe a
Just LspId @f m
origId) (ResponseError
-> Either ResponseError (MessageResult @f @'Request m)
forall a b. a -> Either a b
Left ResponseError
err)
initializeErrorHandler :: (ResponseError -> IO ()) -> E.SomeException -> IO (Maybe a)
initializeErrorHandler :: forall a. (ResponseError -> IO ()) -> SomeException -> IO (Maybe a)
initializeErrorHandler ResponseError -> IO ()
sendResp SomeException
e = do
ResponseError -> IO ()
sendResp (ResponseError -> IO ()) -> ResponseError -> IO ()
forall a b. (a -> b) -> a -> b
$ (LSPErrorCodes |? ErrorCodes)
-> Text -> Maybe Value -> ResponseError
ResponseError (ErrorCodes -> LSPErrorCodes |? ErrorCodes
forall a b. b -> a |? b
InR ErrorCodes
ErrorCodes_InternalError) Text
msg Maybe Value
forall a. Maybe a
Nothing
Maybe a -> IO (Maybe a)
forall a. a -> IO a
forall (f :: * -> *) a. Applicative f => a -> f a
pure Maybe a
forall a. Maybe a
Nothing
where
msg :: Text
msg = String -> Text
T.pack (String -> Text) -> String -> Text
forall a b. (a -> b) -> a -> b
$ [String] -> String
unwords [String
"Error on initialize:", SomeException -> String
forall a. Show a => a -> String
show SomeException
e]
inferServerCapabilities :: ClientCapabilities -> Options -> Handlers m -> ServerCapabilities
inferServerCapabilities :: forall (m :: * -> *).
ClientCapabilities -> Options -> Handlers m -> ServerCapabilities
inferServerCapabilities ClientCapabilities
clientCaps Options
o Handlers m
h =
ServerCapabilities
{ $sel:_textDocumentSync:ServerCapabilities :: Maybe (TextDocumentSyncOptions |? TextDocumentSyncKind)
_textDocumentSync = Maybe (TextDocumentSyncOptions |? TextDocumentSyncKind)
sync
, $sel:_hoverProvider:ServerCapabilities :: Maybe (Bool |? HoverOptions)
_hoverProvider = SClientMethod @'Request 'Method_TextDocumentHover
-> Maybe (Bool |? HoverOptions)
forall {t :: MessageKind} {m :: Method 'ClientToServer t} {b}.
SClientMethod @t m -> Maybe (Bool |? b)
supportedBool SClientMethod @'Request 'Method_TextDocumentHover
SMethod_TextDocumentHover
, $sel:_completionProvider:ServerCapabilities :: Maybe CompletionOptions
_completionProvider = Maybe CompletionOptions
completionProvider
, $sel:_inlayHintProvider:ServerCapabilities :: Maybe (Bool |? (InlayHintOptions |? InlayHintRegistrationOptions))
_inlayHintProvider = Maybe (Bool |? (InlayHintOptions |? InlayHintRegistrationOptions))
forall {a} {b}. Maybe (a |? (InlayHintOptions |? b))
inlayProvider
, $sel:_declarationProvider:ServerCapabilities :: Maybe
(Bool |? (DeclarationOptions |? DeclarationRegistrationOptions))
_declarationProvider = SClientMethod @'Request 'Method_TextDocumentDeclaration
-> Maybe
(Bool |? (DeclarationOptions |? DeclarationRegistrationOptions))
forall {t :: MessageKind} {m :: Method 'ClientToServer t} {b}.
SClientMethod @t m -> Maybe (Bool |? b)
supportedBool SClientMethod @'Request 'Method_TextDocumentDeclaration
SMethod_TextDocumentDeclaration
, $sel:_signatureHelpProvider:ServerCapabilities :: Maybe SignatureHelpOptions
_signatureHelpProvider = Maybe SignatureHelpOptions
signatureHelpProvider
, $sel:_definitionProvider:ServerCapabilities :: Maybe (Bool |? DefinitionOptions)
_definitionProvider = SClientMethod @'Request 'Method_TextDocumentDefinition
-> Maybe (Bool |? DefinitionOptions)
forall {t :: MessageKind} {m :: Method 'ClientToServer t} {b}.
SClientMethod @t m -> Maybe (Bool |? b)
supportedBool SClientMethod @'Request 'Method_TextDocumentDefinition
SMethod_TextDocumentDefinition
, $sel:_typeDefinitionProvider:ServerCapabilities :: Maybe
(Bool
|? (TypeDefinitionOptions |? TypeDefinitionRegistrationOptions))
_typeDefinitionProvider = SClientMethod @'Request 'Method_TextDocumentTypeDefinition
-> Maybe
(Bool
|? (TypeDefinitionOptions |? TypeDefinitionRegistrationOptions))
forall {t :: MessageKind} {m :: Method 'ClientToServer t} {b}.
SClientMethod @t m -> Maybe (Bool |? b)
supportedBool SClientMethod @'Request 'Method_TextDocumentTypeDefinition
SMethod_TextDocumentTypeDefinition
, $sel:_implementationProvider:ServerCapabilities :: Maybe
(Bool
|? (ImplementationOptions |? ImplementationRegistrationOptions))
_implementationProvider = SClientMethod @'Request 'Method_TextDocumentImplementation
-> Maybe
(Bool
|? (ImplementationOptions |? ImplementationRegistrationOptions))
forall {t :: MessageKind} {m :: Method 'ClientToServer t} {b}.
SClientMethod @t m -> Maybe (Bool |? b)
supportedBool SClientMethod @'Request 'Method_TextDocumentImplementation
SMethod_TextDocumentImplementation
, $sel:_referencesProvider:ServerCapabilities :: Maybe (Bool |? ReferenceOptions)
_referencesProvider = SClientMethod @'Request 'Method_TextDocumentReferences
-> Maybe (Bool |? ReferenceOptions)
forall {t :: MessageKind} {m :: Method 'ClientToServer t} {b}.
SClientMethod @t m -> Maybe (Bool |? b)
supportedBool SClientMethod @'Request 'Method_TextDocumentReferences
SMethod_TextDocumentReferences
, $sel:_documentHighlightProvider:ServerCapabilities :: Maybe (Bool |? DocumentHighlightOptions)
_documentHighlightProvider = SClientMethod @'Request 'Method_TextDocumentDocumentHighlight
-> Maybe (Bool |? DocumentHighlightOptions)
forall {t :: MessageKind} {m :: Method 'ClientToServer t} {b}.
SClientMethod @t m -> Maybe (Bool |? b)
supportedBool SClientMethod @'Request 'Method_TextDocumentDocumentHighlight
SMethod_TextDocumentDocumentHighlight
, $sel:_documentSymbolProvider:ServerCapabilities :: Maybe (Bool |? DocumentSymbolOptions)
_documentSymbolProvider = SClientMethod @'Request 'Method_TextDocumentDocumentSymbol
-> Maybe (Bool |? DocumentSymbolOptions)
forall {t :: MessageKind} {m :: Method 'ClientToServer t} {b}.
SClientMethod @t m -> Maybe (Bool |? b)
supportedBool SClientMethod @'Request 'Method_TextDocumentDocumentSymbol
SMethod_TextDocumentDocumentSymbol
, $sel:_codeActionProvider:ServerCapabilities :: Maybe (Bool |? CodeActionOptions)
_codeActionProvider = Maybe (Bool |? CodeActionOptions)
codeActionProvider
, $sel:_codeLensProvider:ServerCapabilities :: Maybe CodeLensOptions
_codeLensProvider =
SClientMethod @'Request 'Method_TextDocumentCodeLens
-> CodeLensOptions -> Maybe CodeLensOptions
forall {t :: MessageKind} {m :: Method 'ClientToServer t} {a}.
SClientMethod @t m -> a -> Maybe a
supported' SClientMethod @'Request 'Method_TextDocumentCodeLens
SMethod_TextDocumentCodeLens (CodeLensOptions -> Maybe CodeLensOptions)
-> CodeLensOptions -> Maybe CodeLensOptions
forall a b. (a -> b) -> a -> b
$
Maybe Bool -> Maybe Bool -> CodeLensOptions
CodeLensOptions
(Bool -> Maybe Bool
forall a. a -> Maybe a
Just Bool
False)
(SClientMethod @'Request 'Method_CodeLensResolve -> Maybe Bool
forall {t :: MessageKind} (m :: Method 'ClientToServer t).
SClientMethod @t m -> Maybe Bool
supported SClientMethod @'Request 'Method_CodeLensResolve
SMethod_CodeLensResolve)
, $sel:_documentFormattingProvider:ServerCapabilities :: Maybe (Bool |? DocumentFormattingOptions)
_documentFormattingProvider = SClientMethod @'Request 'Method_TextDocumentFormatting
-> Maybe (Bool |? DocumentFormattingOptions)
forall {t :: MessageKind} {m :: Method 'ClientToServer t} {b}.
SClientMethod @t m -> Maybe (Bool |? b)
supportedBool SClientMethod @'Request 'Method_TextDocumentFormatting
SMethod_TextDocumentFormatting
, $sel:_documentRangeFormattingProvider:ServerCapabilities :: Maybe (Bool |? DocumentRangeFormattingOptions)
_documentRangeFormattingProvider = SClientMethod @'Request 'Method_TextDocumentRangeFormatting
-> Maybe (Bool |? DocumentRangeFormattingOptions)
forall {t :: MessageKind} {m :: Method 'ClientToServer t} {b}.
SClientMethod @t m -> Maybe (Bool |? b)
supportedBool SClientMethod @'Request 'Method_TextDocumentRangeFormatting
SMethod_TextDocumentRangeFormatting
, $sel:_documentOnTypeFormattingProvider:ServerCapabilities :: Maybe DocumentOnTypeFormattingOptions
_documentOnTypeFormattingProvider = Maybe DocumentOnTypeFormattingOptions
documentOnTypeFormattingProvider
, $sel:_renameProvider:ServerCapabilities :: Maybe (Bool |? RenameOptions)
_renameProvider = Maybe (Bool |? RenameOptions)
renameProvider
, $sel:_documentLinkProvider:ServerCapabilities :: Maybe DocumentLinkOptions
_documentLinkProvider =
SClientMethod @'Request 'Method_TextDocumentDocumentLink
-> DocumentLinkOptions -> Maybe DocumentLinkOptions
forall {t :: MessageKind} {m :: Method 'ClientToServer t} {a}.
SClientMethod @t m -> a -> Maybe a
supported' SClientMethod @'Request 'Method_TextDocumentDocumentLink
SMethod_TextDocumentDocumentLink (DocumentLinkOptions -> Maybe DocumentLinkOptions)
-> DocumentLinkOptions -> Maybe DocumentLinkOptions
forall a b. (a -> b) -> a -> b
$
Maybe Bool -> Maybe Bool -> DocumentLinkOptions
DocumentLinkOptions
(Bool -> Maybe Bool
forall a. a -> Maybe a
Just Bool
False)
(SClientMethod @'Request 'Method_DocumentLinkResolve -> Maybe Bool
forall {t :: MessageKind} (m :: Method 'ClientToServer t).
SClientMethod @t m -> Maybe Bool
supported SClientMethod @'Request 'Method_DocumentLinkResolve
SMethod_DocumentLinkResolve)
, $sel:_colorProvider:ServerCapabilities :: Maybe
(Bool
|? (DocumentColorOptions |? DocumentColorRegistrationOptions))
_colorProvider = SClientMethod @'Request 'Method_TextDocumentDocumentColor
-> Maybe
(Bool
|? (DocumentColorOptions |? DocumentColorRegistrationOptions))
forall {t :: MessageKind} {m :: Method 'ClientToServer t} {b}.
SClientMethod @t m -> Maybe (Bool |? b)
supportedBool SClientMethod @'Request 'Method_TextDocumentDocumentColor
SMethod_TextDocumentDocumentColor
, $sel:_foldingRangeProvider:ServerCapabilities :: Maybe
(Bool |? (FoldingRangeOptions |? FoldingRangeRegistrationOptions))
_foldingRangeProvider = SClientMethod @'Request 'Method_TextDocumentFoldingRange
-> Maybe
(Bool |? (FoldingRangeOptions |? FoldingRangeRegistrationOptions))
forall {t :: MessageKind} {m :: Method 'ClientToServer t} {b}.
SClientMethod @t m -> Maybe (Bool |? b)
supportedBool SClientMethod @'Request 'Method_TextDocumentFoldingRange
SMethod_TextDocumentFoldingRange
, $sel:_executeCommandProvider:ServerCapabilities :: Maybe ExecuteCommandOptions
_executeCommandProvider = Maybe ExecuteCommandOptions
executeCommandProvider
, $sel:_selectionRangeProvider:ServerCapabilities :: Maybe
(Bool
|? (SelectionRangeOptions |? SelectionRangeRegistrationOptions))
_selectionRangeProvider = SClientMethod @'Request 'Method_TextDocumentSelectionRange
-> Maybe
(Bool
|? (SelectionRangeOptions |? SelectionRangeRegistrationOptions))
forall {t :: MessageKind} {m :: Method 'ClientToServer t} {b}.
SClientMethod @t m -> Maybe (Bool |? b)
supportedBool SClientMethod @'Request 'Method_TextDocumentSelectionRange
SMethod_TextDocumentSelectionRange
, $sel:_callHierarchyProvider:ServerCapabilities :: Maybe
(Bool
|? (CallHierarchyOptions |? CallHierarchyRegistrationOptions))
_callHierarchyProvider = SClientMethod @'Request 'Method_TextDocumentPrepareCallHierarchy
-> Maybe
(Bool
|? (CallHierarchyOptions |? CallHierarchyRegistrationOptions))
forall {t :: MessageKind} {m :: Method 'ClientToServer t} {b}.
SClientMethod @t m -> Maybe (Bool |? b)
supportedBool SClientMethod @'Request 'Method_TextDocumentPrepareCallHierarchy
SMethod_TextDocumentPrepareCallHierarchy
, $sel:_semanticTokensProvider:ServerCapabilities :: Maybe (SemanticTokensOptions |? SemanticTokensRegistrationOptions)
_semanticTokensProvider = Maybe (SemanticTokensOptions |? SemanticTokensRegistrationOptions)
forall {b}. Maybe (SemanticTokensOptions |? b)
semanticTokensProvider
, $sel:_workspaceSymbolProvider:ServerCapabilities :: Maybe (Bool |? WorkspaceSymbolOptions)
_workspaceSymbolProvider = SClientMethod @'Request 'Method_WorkspaceSymbol
-> Maybe (Bool |? WorkspaceSymbolOptions)
forall {t :: MessageKind} {m :: Method 'ClientToServer t} {b}.
SClientMethod @t m -> Maybe (Bool |? b)
supportedBool SClientMethod @'Request 'Method_WorkspaceSymbol
SMethod_WorkspaceSymbol
, $sel:_workspace:ServerCapabilities :: Maybe
(Rec
((.+)
@(*)
((.==)
@(*) "workspaceFolders" (Maybe WorkspaceFoldersServerCapabilities))
((.+)
@(*)
((.==) @(*) "fileOperations" (Maybe FileOperationOptions))
(Empty @(*)))))
_workspace = Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "fileOperations" (Maybe FileOperationOptions))
((':)
@(LT (*))
((':->)
@(*) "workspaceFolders" (Maybe WorkspaceFoldersServerCapabilities))
('[] @(LT (*))))))
-> Maybe
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "fileOperations" (Maybe FileOperationOptions))
((':)
@(LT (*))
((':->)
@(*) "workspaceFolders" (Maybe WorkspaceFoldersServerCapabilities))
('[] @(LT (*)))))))
forall a. a -> Maybe a
Just Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "fileOperations" (Maybe FileOperationOptions))
((':)
@(LT (*))
((':->)
@(*) "workspaceFolders" (Maybe WorkspaceFoldersServerCapabilities))
('[] @(LT (*))))))
forall {a}.
Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "fileOperations" (Maybe a))
((':)
@(LT (*))
((':->)
@(*) "workspaceFolders" (Maybe WorkspaceFoldersServerCapabilities))
('[] @(LT (*))))))
workspace
, $sel:_experimental:ServerCapabilities :: Maybe Value
_experimental = Maybe Value
forall a. Maybe a
Nothing :: Maybe Value
,
$sel:_positionEncoding:ServerCapabilities :: Maybe PositionEncodingKind
_positionEncoding = PositionEncodingKind -> Maybe PositionEncodingKind
forall a. a -> Maybe a
Just PositionEncodingKind
PositionEncodingKind_UTF16
, $sel:_linkedEditingRangeProvider:ServerCapabilities :: Maybe
(Bool
|? (LinkedEditingRangeOptions
|? LinkedEditingRangeRegistrationOptions))
_linkedEditingRangeProvider =
SClientMethod @'Request 'Method_TextDocumentLinkedEditingRange
-> (Bool
|? (LinkedEditingRangeOptions
|? LinkedEditingRangeRegistrationOptions))
-> Maybe
(Bool
|? (LinkedEditingRangeOptions
|? LinkedEditingRangeRegistrationOptions))
forall {t :: MessageKind} {m :: Method 'ClientToServer t} {a}.
SClientMethod @t m -> a -> Maybe a
supported' SClientMethod @'Request 'Method_TextDocumentLinkedEditingRange
SMethod_TextDocumentLinkedEditingRange ((Bool
|? (LinkedEditingRangeOptions
|? LinkedEditingRangeRegistrationOptions))
-> Maybe
(Bool
|? (LinkedEditingRangeOptions
|? LinkedEditingRangeRegistrationOptions)))
-> (Bool
|? (LinkedEditingRangeOptions
|? LinkedEditingRangeRegistrationOptions))
-> Maybe
(Bool
|? (LinkedEditingRangeOptions
|? LinkedEditingRangeRegistrationOptions))
forall a b. (a -> b) -> a -> b
$
(LinkedEditingRangeOptions
|? LinkedEditingRangeRegistrationOptions)
-> Bool
|? (LinkedEditingRangeOptions
|? LinkedEditingRangeRegistrationOptions)
forall a b. b -> a |? b
InR ((LinkedEditingRangeOptions
|? LinkedEditingRangeRegistrationOptions)
-> Bool
|? (LinkedEditingRangeOptions
|? LinkedEditingRangeRegistrationOptions))
-> (LinkedEditingRangeOptions
|? LinkedEditingRangeRegistrationOptions)
-> Bool
|? (LinkedEditingRangeOptions
|? LinkedEditingRangeRegistrationOptions)
forall a b. (a -> b) -> a -> b
$
LinkedEditingRangeOptions
-> LinkedEditingRangeOptions
|? LinkedEditingRangeRegistrationOptions
forall a b. a -> a |? b
InL (LinkedEditingRangeOptions
-> LinkedEditingRangeOptions
|? LinkedEditingRangeRegistrationOptions)
-> LinkedEditingRangeOptions
-> LinkedEditingRangeOptions
|? LinkedEditingRangeRegistrationOptions
forall a b. (a -> b) -> a -> b
$
LinkedEditingRangeOptions{$sel:_workDoneProgress:LinkedEditingRangeOptions :: Maybe Bool
_workDoneProgress = Maybe Bool
forall a. Maybe a
Nothing}
, $sel:_monikerProvider:ServerCapabilities :: Maybe (Bool |? (MonikerOptions |? MonikerRegistrationOptions))
_monikerProvider =
SClientMethod @'Request 'Method_TextDocumentMoniker
-> (Bool |? (MonikerOptions |? MonikerRegistrationOptions))
-> Maybe (Bool |? (MonikerOptions |? MonikerRegistrationOptions))
forall {t :: MessageKind} {m :: Method 'ClientToServer t} {a}.
SClientMethod @t m -> a -> Maybe a
supported' SClientMethod @'Request 'Method_TextDocumentMoniker
SMethod_TextDocumentMoniker ((Bool |? (MonikerOptions |? MonikerRegistrationOptions))
-> Maybe (Bool |? (MonikerOptions |? MonikerRegistrationOptions)))
-> (Bool |? (MonikerOptions |? MonikerRegistrationOptions))
-> Maybe (Bool |? (MonikerOptions |? MonikerRegistrationOptions))
forall a b. (a -> b) -> a -> b
$
(MonikerOptions |? MonikerRegistrationOptions)
-> Bool |? (MonikerOptions |? MonikerRegistrationOptions)
forall a b. b -> a |? b
InR ((MonikerOptions |? MonikerRegistrationOptions)
-> Bool |? (MonikerOptions |? MonikerRegistrationOptions))
-> (MonikerOptions |? MonikerRegistrationOptions)
-> Bool |? (MonikerOptions |? MonikerRegistrationOptions)
forall a b. (a -> b) -> a -> b
$
MonikerOptions -> MonikerOptions |? MonikerRegistrationOptions
forall a b. a -> a |? b
InL (MonikerOptions -> MonikerOptions |? MonikerRegistrationOptions)
-> MonikerOptions -> MonikerOptions |? MonikerRegistrationOptions
forall a b. (a -> b) -> a -> b
$
MonikerOptions{$sel:_workDoneProgress:MonikerOptions :: Maybe Bool
_workDoneProgress = Maybe Bool
forall a. Maybe a
Nothing}
, $sel:_typeHierarchyProvider:ServerCapabilities :: Maybe
(Bool
|? (TypeHierarchyOptions |? TypeHierarchyRegistrationOptions))
_typeHierarchyProvider =
SClientMethod @'Request 'Method_TextDocumentPrepareTypeHierarchy
-> (Bool
|? (TypeHierarchyOptions |? TypeHierarchyRegistrationOptions))
-> Maybe
(Bool
|? (TypeHierarchyOptions |? TypeHierarchyRegistrationOptions))
forall {t :: MessageKind} {m :: Method 'ClientToServer t} {a}.
SClientMethod @t m -> a -> Maybe a
supported' SClientMethod @'Request 'Method_TextDocumentPrepareTypeHierarchy
SMethod_TextDocumentPrepareTypeHierarchy ((Bool
|? (TypeHierarchyOptions |? TypeHierarchyRegistrationOptions))
-> Maybe
(Bool
|? (TypeHierarchyOptions |? TypeHierarchyRegistrationOptions)))
-> (Bool
|? (TypeHierarchyOptions |? TypeHierarchyRegistrationOptions))
-> Maybe
(Bool
|? (TypeHierarchyOptions |? TypeHierarchyRegistrationOptions))
forall a b. (a -> b) -> a -> b
$
(TypeHierarchyOptions |? TypeHierarchyRegistrationOptions)
-> Bool
|? (TypeHierarchyOptions |? TypeHierarchyRegistrationOptions)
forall a b. b -> a |? b
InR ((TypeHierarchyOptions |? TypeHierarchyRegistrationOptions)
-> Bool
|? (TypeHierarchyOptions |? TypeHierarchyRegistrationOptions))
-> (TypeHierarchyOptions |? TypeHierarchyRegistrationOptions)
-> Bool
|? (TypeHierarchyOptions |? TypeHierarchyRegistrationOptions)
forall a b. (a -> b) -> a -> b
$
TypeHierarchyOptions
-> TypeHierarchyOptions |? TypeHierarchyRegistrationOptions
forall a b. a -> a |? b
InL (TypeHierarchyOptions
-> TypeHierarchyOptions |? TypeHierarchyRegistrationOptions)
-> TypeHierarchyOptions
-> TypeHierarchyOptions |? TypeHierarchyRegistrationOptions
forall a b. (a -> b) -> a -> b
$
TypeHierarchyOptions{$sel:_workDoneProgress:TypeHierarchyOptions :: Maybe Bool
_workDoneProgress = Maybe Bool
forall a. Maybe a
Nothing}
, $sel:_inlineValueProvider:ServerCapabilities :: Maybe
(Bool |? (InlineValueOptions |? InlineValueRegistrationOptions))
_inlineValueProvider =
SClientMethod @'Request 'Method_TextDocumentInlineValue
-> (Bool |? (InlineValueOptions |? InlineValueRegistrationOptions))
-> Maybe
(Bool |? (InlineValueOptions |? InlineValueRegistrationOptions))
forall {t :: MessageKind} {m :: Method 'ClientToServer t} {a}.
SClientMethod @t m -> a -> Maybe a
supported' SClientMethod @'Request 'Method_TextDocumentInlineValue
SMethod_TextDocumentInlineValue ((Bool |? (InlineValueOptions |? InlineValueRegistrationOptions))
-> Maybe
(Bool |? (InlineValueOptions |? InlineValueRegistrationOptions)))
-> (Bool |? (InlineValueOptions |? InlineValueRegistrationOptions))
-> Maybe
(Bool |? (InlineValueOptions |? InlineValueRegistrationOptions))
forall a b. (a -> b) -> a -> b
$
(InlineValueOptions |? InlineValueRegistrationOptions)
-> Bool |? (InlineValueOptions |? InlineValueRegistrationOptions)
forall a b. b -> a |? b
InR ((InlineValueOptions |? InlineValueRegistrationOptions)
-> Bool |? (InlineValueOptions |? InlineValueRegistrationOptions))
-> (InlineValueOptions |? InlineValueRegistrationOptions)
-> Bool |? (InlineValueOptions |? InlineValueRegistrationOptions)
forall a b. (a -> b) -> a -> b
$
InlineValueOptions
-> InlineValueOptions |? InlineValueRegistrationOptions
forall a b. a -> a |? b
InL (InlineValueOptions
-> InlineValueOptions |? InlineValueRegistrationOptions)
-> InlineValueOptions
-> InlineValueOptions |? InlineValueRegistrationOptions
forall a b. (a -> b) -> a -> b
$
InlineValueOptions{$sel:_workDoneProgress:InlineValueOptions :: Maybe Bool
_workDoneProgress = Maybe Bool
forall a. Maybe a
Nothing}
, $sel:_diagnosticProvider:ServerCapabilities :: Maybe (DiagnosticOptions |? DiagnosticRegistrationOptions)
_diagnosticProvider = Maybe (DiagnosticOptions |? DiagnosticRegistrationOptions)
forall {b}. Maybe (DiagnosticOptions |? b)
diagnosticProvider
,
$sel:_notebookDocumentSync:ServerCapabilities :: Maybe
(NotebookDocumentSyncOptions
|? NotebookDocumentSyncRegistrationOptions)
_notebookDocumentSync = Maybe
(NotebookDocumentSyncOptions
|? NotebookDocumentSyncRegistrationOptions)
forall a. Maybe a
Nothing
}
where
supportedBool :: SClientMethod @t m -> Maybe (Bool |? b)
supportedBool = (Bool |? b) -> Maybe (Bool |? b)
forall a. a -> Maybe a
Just ((Bool |? b) -> Maybe (Bool |? b))
-> (SClientMethod @t m -> Bool |? b)
-> SClientMethod @t m
-> Maybe (Bool |? b)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Bool -> Bool |? b
forall a b. a -> a |? b
InL (Bool -> Bool |? b)
-> (SClientMethod @t m -> Bool) -> SClientMethod @t m -> Bool |? b
forall b c a. (b -> c) -> (a -> b) -> a -> c
. SClientMethod @t m -> Bool
forall {t :: MessageKind} (m :: Method 'ClientToServer t).
SClientMethod @t m -> Bool
supported_b
supported' :: SClientMethod @t m -> a -> Maybe a
supported' SClientMethod @t m
m a
b
| SClientMethod @t m -> Bool
forall {t :: MessageKind} (m :: Method 'ClientToServer t).
SClientMethod @t m -> Bool
supported_b SClientMethod @t m
m = a -> Maybe a
forall a. a -> Maybe a
Just a
b
| Bool
otherwise = Maybe a
forall a. Maybe a
Nothing
supported :: forall m. SClientMethod m -> Maybe Bool
supported :: forall {t :: MessageKind} (m :: Method 'ClientToServer t).
SClientMethod @t m -> Maybe Bool
supported = Bool -> Maybe Bool
forall a. a -> Maybe a
Just (Bool -> Maybe Bool)
-> (SClientMethod @t m -> Bool) -> SClientMethod @t m -> Maybe Bool
forall b c a. (b -> c) -> (a -> b) -> a -> c
. SClientMethod @t m -> Bool
forall {t :: MessageKind} (m :: Method 'ClientToServer t).
SClientMethod @t m -> Bool
supported_b
supported_b :: forall m. SClientMethod m -> Bool
supported_b :: forall {t :: MessageKind} (m :: Method 'ClientToServer t).
SClientMethod @t m -> Bool
supported_b SClientMethod @t m
m = case SClientMethod @t m -> ClientNotOrReq @t m
forall {t :: MessageKind} (m :: Method 'ClientToServer t).
SClientMethod @t m -> ClientNotOrReq @t m
splitClientMethod SClientMethod @t m
m of
ClientNotOrReq @t m
IsClientNot -> SClientMethod @t m
-> SMethodMap
@'ClientToServer
@'Notification
(ClientMessageHandler m 'Notification)
-> Bool
forall {f1 :: MessageDirection} {t1 :: MessageKind}
{f2 :: MessageDirection} {t2 :: MessageKind} (a :: Method f1 t1)
(v :: Method f2 t2 -> *).
SMethod @f1 @t1 a -> SMethodMap @f2 @t2 v -> Bool
SMethodMap.member SClientMethod @t m
m (SMethodMap
@'ClientToServer
@'Notification
(ClientMessageHandler m 'Notification)
-> Bool)
-> SMethodMap
@'ClientToServer
@'Notification
(ClientMessageHandler m 'Notification)
-> Bool
forall a b. (a -> b) -> a -> b
$ Handlers m
-> SMethodMap
@'ClientToServer
@'Notification
(ClientMessageHandler m 'Notification)
forall (m :: * -> *).
Handlers m
-> SMethodMap
@'ClientToServer
@'Notification
(ClientMessageHandler m 'Notification)
notHandlers Handlers m
h
ClientNotOrReq @t m
IsClientReq -> SClientMethod @t m
-> SMethodMap
@'ClientToServer @'Request (ClientMessageHandler m 'Request)
-> Bool
forall {f1 :: MessageDirection} {t1 :: MessageKind}
{f2 :: MessageDirection} {t2 :: MessageKind} (a :: Method f1 t1)
(v :: Method f2 t2 -> *).
SMethod @f1 @t1 a -> SMethodMap @f2 @t2 v -> Bool
SMethodMap.member SClientMethod @t m
m (SMethodMap
@'ClientToServer @'Request (ClientMessageHandler m 'Request)
-> Bool)
-> SMethodMap
@'ClientToServer @'Request (ClientMessageHandler m 'Request)
-> Bool
forall a b. (a -> b) -> a -> b
$ Handlers m
-> SMethodMap
@'ClientToServer @'Request (ClientMessageHandler m 'Request)
forall (m :: * -> *).
Handlers m
-> SMethodMap
@'ClientToServer @'Request (ClientMessageHandler m 'Request)
reqHandlers Handlers m
h
ClientNotOrReq @t m
IsClientEither -> String -> Bool
forall a. HasCallStack => String -> a
error String
"capabilities depend on custom method"
singleton :: a -> [a]
singleton :: forall a. a -> [a]
singleton a
x = [a
x]
completionProvider :: Maybe CompletionOptions
completionProvider
| SClientMethod @'Request 'Method_TextDocumentCompletion -> Bool
forall {t :: MessageKind} (m :: Method 'ClientToServer t).
SClientMethod @t m -> Bool
supported_b SClientMethod @'Request 'Method_TextDocumentCompletion
SMethod_TextDocumentCompletion =
CompletionOptions -> Maybe CompletionOptions
forall a. a -> Maybe a
Just (CompletionOptions -> Maybe CompletionOptions)
-> CompletionOptions -> Maybe CompletionOptions
forall a b. (a -> b) -> a -> b
$
CompletionOptions
{ $sel:_triggerCharacters:CompletionOptions :: Maybe [Text]
_triggerCharacters = (Char -> Text) -> String -> [Text]
forall a b. (a -> b) -> [a] -> [b]
map Char -> Text
T.singleton (String -> [Text]) -> Maybe String -> Maybe [Text]
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Options -> Maybe String
optCompletionTriggerCharacters Options
o
, $sel:_allCommitCharacters:CompletionOptions :: Maybe [Text]
_allCommitCharacters = (Char -> Text) -> String -> [Text]
forall a b. (a -> b) -> [a] -> [b]
map Char -> Text
T.singleton (String -> [Text]) -> Maybe String -> Maybe [Text]
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Options -> Maybe String
optCompletionAllCommitCharacters Options
o
, $sel:_resolveProvider:CompletionOptions :: Maybe Bool
_resolveProvider = SClientMethod @'Request 'Method_CompletionItemResolve -> Maybe Bool
forall {t :: MessageKind} (m :: Method 'ClientToServer t).
SClientMethod @t m -> Maybe Bool
supported SClientMethod @'Request 'Method_CompletionItemResolve
SMethod_CompletionItemResolve
, $sel:_completionItem:CompletionOptions :: Maybe
(Rec
((.+)
@(*) ((.==) @(*) "labelDetailsSupport" (Maybe Bool)) (Empty @(*))))
_completionItem = Maybe
(Rec
((.+)
@(*) ((.==) @(*) "labelDetailsSupport" (Maybe Bool)) (Empty @(*))))
Maybe
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "labelDetailsSupport" (Maybe Bool))
('[] @(LT (*))))))
forall a. Maybe a
Nothing
, $sel:_workDoneProgress:CompletionOptions :: Maybe Bool
_workDoneProgress = Maybe Bool
forall a. Maybe a
Nothing
}
| Bool
otherwise = Maybe CompletionOptions
forall a. Maybe a
Nothing
inlayProvider :: Maybe (a |? (InlayHintOptions |? b))
inlayProvider
| SClientMethod @'Request 'Method_TextDocumentInlayHint -> Bool
forall {t :: MessageKind} (m :: Method 'ClientToServer t).
SClientMethod @t m -> Bool
supported_b SClientMethod @'Request 'Method_TextDocumentInlayHint
SMethod_TextDocumentInlayHint =
(a |? (InlayHintOptions |? b))
-> Maybe (a |? (InlayHintOptions |? b))
forall a. a -> Maybe a
Just ((a |? (InlayHintOptions |? b))
-> Maybe (a |? (InlayHintOptions |? b)))
-> (a |? (InlayHintOptions |? b))
-> Maybe (a |? (InlayHintOptions |? b))
forall a b. (a -> b) -> a -> b
$
(InlayHintOptions |? b) -> a |? (InlayHintOptions |? b)
forall a b. b -> a |? b
InR ((InlayHintOptions |? b) -> a |? (InlayHintOptions |? b))
-> (InlayHintOptions |? b) -> a |? (InlayHintOptions |? b)
forall a b. (a -> b) -> a -> b
$
InlayHintOptions -> InlayHintOptions |? b
forall a b. a -> a |? b
InL
InlayHintOptions
{ $sel:_workDoneProgress:InlayHintOptions :: Maybe Bool
_workDoneProgress = Maybe Bool
forall a. Maybe a
Nothing
, $sel:_resolveProvider:InlayHintOptions :: Maybe Bool
_resolveProvider = SClientMethod @'Request 'Method_InlayHintResolve -> Maybe Bool
forall {t :: MessageKind} (m :: Method 'ClientToServer t).
SClientMethod @t m -> Maybe Bool
supported SClientMethod @'Request 'Method_InlayHintResolve
SMethod_InlayHintResolve
}
| Bool
otherwise = Maybe (a |? (InlayHintOptions |? b))
forall a. Maybe a
Nothing
clientSupportsCodeActionKinds :: Bool
clientSupportsCodeActionKinds =
Maybe
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*))))))
-> Bool
forall a. Maybe a -> Bool
isJust (Maybe
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*))))))
-> Bool)
-> Maybe
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*))))))
-> Bool
forall a b. (a -> b) -> a -> b
$
ClientCapabilities
clientCaps ClientCapabilities
-> Getting
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
ClientCapabilities
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*))))))
-> Maybe
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*))))))
forall s a. s -> Getting (First a) s a -> Maybe a
^? (Maybe TextDocumentClientCapabilities
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
(Maybe TextDocumentClientCapabilities))
-> ClientCapabilities
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
ClientCapabilities
forall s a. HasTextDocument s a => Lens' s a
Lens' ClientCapabilities (Maybe TextDocumentClientCapabilities)
L.textDocument ((Maybe TextDocumentClientCapabilities
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
(Maybe TextDocumentClientCapabilities))
-> ClientCapabilities
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
ClientCapabilities)
-> ((Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
-> Maybe TextDocumentClientCapabilities
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
(Maybe TextDocumentClientCapabilities))
-> Getting
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
ClientCapabilities
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*))))))
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (TextDocumentClientCapabilities
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
TextDocumentClientCapabilities)
-> Maybe TextDocumentClientCapabilities
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
(Maybe TextDocumentClientCapabilities)
forall a b (p :: * -> * -> *) (f :: * -> *).
(Choice p, Applicative f) =>
p a (f b) -> p (Maybe a) (f (Maybe b))
_Just ((TextDocumentClientCapabilities
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
TextDocumentClientCapabilities)
-> Maybe TextDocumentClientCapabilities
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
(Maybe TextDocumentClientCapabilities))
-> ((Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
-> TextDocumentClientCapabilities
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
TextDocumentClientCapabilities)
-> (Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
-> Maybe TextDocumentClientCapabilities
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
(Maybe TextDocumentClientCapabilities)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (Maybe CodeActionClientCapabilities
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
(Maybe CodeActionClientCapabilities))
-> TextDocumentClientCapabilities
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
TextDocumentClientCapabilities
forall s a. HasCodeAction s a => Lens' s a
Lens'
TextDocumentClientCapabilities (Maybe CodeActionClientCapabilities)
L.codeAction ((Maybe CodeActionClientCapabilities
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
(Maybe CodeActionClientCapabilities))
-> TextDocumentClientCapabilities
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
TextDocumentClientCapabilities)
-> ((Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
-> Maybe CodeActionClientCapabilities
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
(Maybe CodeActionClientCapabilities))
-> (Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
-> TextDocumentClientCapabilities
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
TextDocumentClientCapabilities
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (CodeActionClientCapabilities
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
CodeActionClientCapabilities)
-> Maybe CodeActionClientCapabilities
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
(Maybe CodeActionClientCapabilities)
forall a b (p :: * -> * -> *) (f :: * -> *).
(Choice p, Applicative f) =>
p a (f b) -> p (Maybe a) (f (Maybe b))
_Just ((CodeActionClientCapabilities
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
CodeActionClientCapabilities)
-> Maybe CodeActionClientCapabilities
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
(Maybe CodeActionClientCapabilities))
-> ((Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
-> CodeActionClientCapabilities
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
CodeActionClientCapabilities)
-> (Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
-> Maybe CodeActionClientCapabilities
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
(Maybe CodeActionClientCapabilities)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (Maybe
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*))))))
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
(Maybe
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*))))))))
-> CodeActionClientCapabilities
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
CodeActionClientCapabilities
forall s a. HasCodeActionLiteralSupport s a => Lens' s a
Lens'
CodeActionClientCapabilities
(Maybe
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
L.codeActionLiteralSupport ((Maybe
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*))))))
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
(Maybe
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*))))))))
-> CodeActionClientCapabilities
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
CodeActionClientCapabilities)
-> ((Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
-> Maybe
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*))))))
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
(Maybe
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*))))))))
-> (Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
-> CodeActionClientCapabilities
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
CodeActionClientCapabilities
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
-> Maybe
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*))))))
-> Const
@(*)
(First
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
(Maybe
(Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*)
"codeActionKind"
(Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "valueSet" [CodeActionKind])
('[] @(LT (*)))))))
('[] @(LT (*)))))))
forall a b (p :: * -> * -> *) (f :: * -> *).
(Choice p, Applicative f) =>
p a (f b) -> p (Maybe a) (f (Maybe b))
_Just
codeActionProvider :: Maybe (Bool |? CodeActionOptions)
codeActionProvider
| SClientMethod @'Request 'Method_TextDocumentCodeAction -> Bool
forall {t :: MessageKind} (m :: Method 'ClientToServer t).
SClientMethod @t m -> Bool
supported_b SClientMethod @'Request 'Method_TextDocumentCodeAction
SMethod_TextDocumentCodeAction =
(Bool |? CodeActionOptions) -> Maybe (Bool |? CodeActionOptions)
forall a. a -> Maybe a
Just ((Bool |? CodeActionOptions) -> Maybe (Bool |? CodeActionOptions))
-> (Bool |? CodeActionOptions) -> Maybe (Bool |? CodeActionOptions)
forall a b. (a -> b) -> a -> b
$
CodeActionOptions -> Bool |? CodeActionOptions
forall a b. b -> a |? b
InR (CodeActionOptions -> Bool |? CodeActionOptions)
-> CodeActionOptions -> Bool |? CodeActionOptions
forall a b. (a -> b) -> a -> b
$
CodeActionOptions
{ $sel:_workDoneProgress:CodeActionOptions :: Maybe Bool
_workDoneProgress = Maybe Bool
forall a. Maybe a
Nothing
, $sel:_codeActionKinds:CodeActionOptions :: Maybe [CodeActionKind]
_codeActionKinds = Maybe [CodeActionKind] -> Maybe [CodeActionKind]
codeActionKinds (Options -> Maybe [CodeActionKind]
optCodeActionKinds Options
o)
, $sel:_resolveProvider:CodeActionOptions :: Maybe Bool
_resolveProvider = SClientMethod @'Request 'Method_CodeActionResolve -> Maybe Bool
forall {t :: MessageKind} (m :: Method 'ClientToServer t).
SClientMethod @t m -> Maybe Bool
supported SClientMethod @'Request 'Method_CodeActionResolve
SMethod_CodeActionResolve
}
| Bool
otherwise = (Bool |? CodeActionOptions) -> Maybe (Bool |? CodeActionOptions)
forall a. a -> Maybe a
Just (Bool -> Bool |? CodeActionOptions
forall a b. a -> a |? b
InL Bool
False)
codeActionKinds :: Maybe [CodeActionKind] -> Maybe [CodeActionKind]
codeActionKinds (Just [CodeActionKind]
ks)
| Bool
clientSupportsCodeActionKinds = [CodeActionKind] -> Maybe [CodeActionKind]
forall a. a -> Maybe a
Just [CodeActionKind]
ks
codeActionKinds Maybe [CodeActionKind]
_ = Maybe [CodeActionKind]
forall a. Maybe a
Nothing
signatureHelpProvider :: Maybe SignatureHelpOptions
signatureHelpProvider
| SClientMethod @'Request 'Method_TextDocumentSignatureHelp -> Bool
forall {t :: MessageKind} (m :: Method 'ClientToServer t).
SClientMethod @t m -> Bool
supported_b SClientMethod @'Request 'Method_TextDocumentSignatureHelp
SMethod_TextDocumentSignatureHelp =
SignatureHelpOptions -> Maybe SignatureHelpOptions
forall a. a -> Maybe a
Just (SignatureHelpOptions -> Maybe SignatureHelpOptions)
-> SignatureHelpOptions -> Maybe SignatureHelpOptions
forall a b. (a -> b) -> a -> b
$
Maybe Bool -> Maybe [Text] -> Maybe [Text] -> SignatureHelpOptions
SignatureHelpOptions
Maybe Bool
forall a. Maybe a
Nothing
((Char -> Text) -> String -> [Text]
forall a b. (a -> b) -> [a] -> [b]
map Char -> Text
T.singleton (String -> [Text]) -> Maybe String -> Maybe [Text]
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Options -> Maybe String
optSignatureHelpTriggerCharacters Options
o)
((Char -> Text) -> String -> [Text]
forall a b. (a -> b) -> [a] -> [b]
map Char -> Text
T.singleton (String -> [Text]) -> Maybe String -> Maybe [Text]
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Options -> Maybe String
optSignatureHelpRetriggerCharacters Options
o)
| Bool
otherwise = Maybe SignatureHelpOptions
forall a. Maybe a
Nothing
documentOnTypeFormattingProvider :: Maybe DocumentOnTypeFormattingOptions
documentOnTypeFormattingProvider
| SClientMethod @'Request 'Method_TextDocumentOnTypeFormatting
-> Bool
forall {t :: MessageKind} (m :: Method 'ClientToServer t).
SClientMethod @t m -> Bool
supported_b SClientMethod @'Request 'Method_TextDocumentOnTypeFormatting
SMethod_TextDocumentOnTypeFormatting
, Just (Char
first :| String
rest) <- Options -> Maybe (NonEmpty Char)
optDocumentOnTypeFormattingTriggerCharacters Options
o =
DocumentOnTypeFormattingOptions
-> Maybe DocumentOnTypeFormattingOptions
forall a. a -> Maybe a
Just (DocumentOnTypeFormattingOptions
-> Maybe DocumentOnTypeFormattingOptions)
-> DocumentOnTypeFormattingOptions
-> Maybe DocumentOnTypeFormattingOptions
forall a b. (a -> b) -> a -> b
$
Text -> Maybe [Text] -> DocumentOnTypeFormattingOptions
DocumentOnTypeFormattingOptions (String -> Text
T.pack [Char
first]) ([Text] -> Maybe [Text]
forall a. a -> Maybe a
Just ((Char -> Text) -> String -> [Text]
forall a b. (a -> b) -> [a] -> [b]
map (String -> Text
T.pack (String -> Text) -> (Char -> String) -> Char -> Text
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Char -> String
forall a. a -> [a]
singleton) String
rest))
| SClientMethod @'Request 'Method_TextDocumentOnTypeFormatting
-> Bool
forall {t :: MessageKind} (m :: Method 'ClientToServer t).
SClientMethod @t m -> Bool
supported_b SClientMethod @'Request 'Method_TextDocumentOnTypeFormatting
SMethod_TextDocumentOnTypeFormatting
, Maybe (NonEmpty Char)
Nothing <- Options -> Maybe (NonEmpty Char)
optDocumentOnTypeFormattingTriggerCharacters Options
o =
String -> Maybe DocumentOnTypeFormattingOptions
forall a. HasCallStack => String -> a
error String
"documentOnTypeFormattingTriggerCharacters needs to be set if a documentOnTypeFormattingHandler is set"
| Bool
otherwise = Maybe DocumentOnTypeFormattingOptions
forall a. Maybe a
Nothing
executeCommandProvider :: Maybe ExecuteCommandOptions
executeCommandProvider
| SClientMethod @'Request 'Method_WorkspaceExecuteCommand -> Bool
forall {t :: MessageKind} (m :: Method 'ClientToServer t).
SClientMethod @t m -> Bool
supported_b SClientMethod @'Request 'Method_WorkspaceExecuteCommand
SMethod_WorkspaceExecuteCommand
, Just [Text]
cmds <- Options -> Maybe [Text]
optExecuteCommandCommands Options
o =
ExecuteCommandOptions -> Maybe ExecuteCommandOptions
forall a. a -> Maybe a
Just (Maybe Bool -> [Text] -> ExecuteCommandOptions
ExecuteCommandOptions Maybe Bool
forall a. Maybe a
Nothing [Text]
cmds)
| SClientMethod @'Request 'Method_WorkspaceExecuteCommand -> Bool
forall {t :: MessageKind} (m :: Method 'ClientToServer t).
SClientMethod @t m -> Bool
supported_b SClientMethod @'Request 'Method_WorkspaceExecuteCommand
SMethod_WorkspaceExecuteCommand
, Maybe [Text]
Nothing <- Options -> Maybe [Text]
optExecuteCommandCommands Options
o =
String -> Maybe ExecuteCommandOptions
forall a. HasCallStack => String -> a
error String
"executeCommandCommands needs to be set if a executeCommandHandler is set"
| Bool
otherwise = Maybe ExecuteCommandOptions
forall a. Maybe a
Nothing
clientSupportsPrepareRename :: Bool
clientSupportsPrepareRename =
Bool -> Maybe Bool -> Bool
forall a. a -> Maybe a -> a
fromMaybe Bool
False (Maybe Bool -> Bool) -> Maybe Bool -> Bool
forall a b. (a -> b) -> a -> b
$
ClientCapabilities
clientCaps ClientCapabilities
-> Getting (First Bool) ClientCapabilities Bool -> Maybe Bool
forall s a. s -> Getting (First a) s a -> Maybe a
^? (Maybe TextDocumentClientCapabilities
-> Const @(*) (First Bool) (Maybe TextDocumentClientCapabilities))
-> ClientCapabilities -> Const @(*) (First Bool) ClientCapabilities
forall s a. HasTextDocument s a => Lens' s a
Lens' ClientCapabilities (Maybe TextDocumentClientCapabilities)
L.textDocument ((Maybe TextDocumentClientCapabilities
-> Const @(*) (First Bool) (Maybe TextDocumentClientCapabilities))
-> ClientCapabilities
-> Const @(*) (First Bool) ClientCapabilities)
-> ((Bool -> Const @(*) (First Bool) Bool)
-> Maybe TextDocumentClientCapabilities
-> Const @(*) (First Bool) (Maybe TextDocumentClientCapabilities))
-> Getting (First Bool) ClientCapabilities Bool
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (TextDocumentClientCapabilities
-> Const @(*) (First Bool) TextDocumentClientCapabilities)
-> Maybe TextDocumentClientCapabilities
-> Const @(*) (First Bool) (Maybe TextDocumentClientCapabilities)
forall a b (p :: * -> * -> *) (f :: * -> *).
(Choice p, Applicative f) =>
p a (f b) -> p (Maybe a) (f (Maybe b))
_Just ((TextDocumentClientCapabilities
-> Const @(*) (First Bool) TextDocumentClientCapabilities)
-> Maybe TextDocumentClientCapabilities
-> Const @(*) (First Bool) (Maybe TextDocumentClientCapabilities))
-> ((Bool -> Const @(*) (First Bool) Bool)
-> TextDocumentClientCapabilities
-> Const @(*) (First Bool) TextDocumentClientCapabilities)
-> (Bool -> Const @(*) (First Bool) Bool)
-> Maybe TextDocumentClientCapabilities
-> Const @(*) (First Bool) (Maybe TextDocumentClientCapabilities)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (Maybe RenameClientCapabilities
-> Const @(*) (First Bool) (Maybe RenameClientCapabilities))
-> TextDocumentClientCapabilities
-> Const @(*) (First Bool) TextDocumentClientCapabilities
forall s a. HasRename s a => Lens' s a
Lens'
TextDocumentClientCapabilities (Maybe RenameClientCapabilities)
L.rename ((Maybe RenameClientCapabilities
-> Const @(*) (First Bool) (Maybe RenameClientCapabilities))
-> TextDocumentClientCapabilities
-> Const @(*) (First Bool) TextDocumentClientCapabilities)
-> ((Bool -> Const @(*) (First Bool) Bool)
-> Maybe RenameClientCapabilities
-> Const @(*) (First Bool) (Maybe RenameClientCapabilities))
-> (Bool -> Const @(*) (First Bool) Bool)
-> TextDocumentClientCapabilities
-> Const @(*) (First Bool) TextDocumentClientCapabilities
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (RenameClientCapabilities
-> Const @(*) (First Bool) RenameClientCapabilities)
-> Maybe RenameClientCapabilities
-> Const @(*) (First Bool) (Maybe RenameClientCapabilities)
forall a b (p :: * -> * -> *) (f :: * -> *).
(Choice p, Applicative f) =>
p a (f b) -> p (Maybe a) (f (Maybe b))
_Just ((RenameClientCapabilities
-> Const @(*) (First Bool) RenameClientCapabilities)
-> Maybe RenameClientCapabilities
-> Const @(*) (First Bool) (Maybe RenameClientCapabilities))
-> ((Bool -> Const @(*) (First Bool) Bool)
-> RenameClientCapabilities
-> Const @(*) (First Bool) RenameClientCapabilities)
-> (Bool -> Const @(*) (First Bool) Bool)
-> Maybe RenameClientCapabilities
-> Const @(*) (First Bool) (Maybe RenameClientCapabilities)
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (Maybe Bool -> Const @(*) (First Bool) (Maybe Bool))
-> RenameClientCapabilities
-> Const @(*) (First Bool) RenameClientCapabilities
forall s a. HasPrepareSupport s a => Lens' s a
Lens' RenameClientCapabilities (Maybe Bool)
L.prepareSupport ((Maybe Bool -> Const @(*) (First Bool) (Maybe Bool))
-> RenameClientCapabilities
-> Const @(*) (First Bool) RenameClientCapabilities)
-> ((Bool -> Const @(*) (First Bool) Bool)
-> Maybe Bool -> Const @(*) (First Bool) (Maybe Bool))
-> (Bool -> Const @(*) (First Bool) Bool)
-> RenameClientCapabilities
-> Const @(*) (First Bool) RenameClientCapabilities
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (Bool -> Const @(*) (First Bool) Bool)
-> Maybe Bool -> Const @(*) (First Bool) (Maybe Bool)
forall a b (p :: * -> * -> *) (f :: * -> *).
(Choice p, Applicative f) =>
p a (f b) -> p (Maybe a) (f (Maybe b))
_Just
renameProvider :: Maybe (Bool |? RenameOptions)
renameProvider
| Bool
clientSupportsPrepareRename
, SClientMethod @'Request 'Method_TextDocumentRename -> Bool
forall {t :: MessageKind} (m :: Method 'ClientToServer t).
SClientMethod @t m -> Bool
supported_b SClientMethod @'Request 'Method_TextDocumentRename
SMethod_TextDocumentRename
, SClientMethod @'Request 'Method_TextDocumentPrepareRename -> Bool
forall {t :: MessageKind} (m :: Method 'ClientToServer t).
SClientMethod @t m -> Bool
supported_b SClientMethod @'Request 'Method_TextDocumentPrepareRename
SMethod_TextDocumentPrepareRename =
(Bool |? RenameOptions) -> Maybe (Bool |? RenameOptions)
forall a. a -> Maybe a
Just ((Bool |? RenameOptions) -> Maybe (Bool |? RenameOptions))
-> (Bool |? RenameOptions) -> Maybe (Bool |? RenameOptions)
forall a b. (a -> b) -> a -> b
$
RenameOptions -> Bool |? RenameOptions
forall a b. b -> a |? b
InR (RenameOptions -> Bool |? RenameOptions)
-> (Bool -> RenameOptions) -> Bool -> Bool |? RenameOptions
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Maybe Bool -> Maybe Bool -> RenameOptions
RenameOptions Maybe Bool
forall a. Maybe a
Nothing (Maybe Bool -> RenameOptions)
-> (Bool -> Maybe Bool) -> Bool -> RenameOptions
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Bool -> Maybe Bool
forall a. a -> Maybe a
Just (Bool -> Bool |? RenameOptions) -> Bool -> Bool |? RenameOptions
forall a b. (a -> b) -> a -> b
$
Bool
True
| SClientMethod @'Request 'Method_TextDocumentRename -> Bool
forall {t :: MessageKind} (m :: Method 'ClientToServer t).
SClientMethod @t m -> Bool
supported_b SClientMethod @'Request 'Method_TextDocumentRename
SMethod_TextDocumentRename = (Bool |? RenameOptions) -> Maybe (Bool |? RenameOptions)
forall a. a -> Maybe a
Just (Bool -> Bool |? RenameOptions
forall a b. a -> a |? b
InL Bool
True)
| Bool
otherwise = (Bool |? RenameOptions) -> Maybe (Bool |? RenameOptions)
forall a. a -> Maybe a
Just (Bool -> Bool |? RenameOptions
forall a b. a -> a |? b
InL Bool
False)
semanticTokensProvider :: Maybe (SemanticTokensOptions |? b)
semanticTokensProvider = (SemanticTokensOptions |? b) -> Maybe (SemanticTokensOptions |? b)
forall a. a -> Maybe a
Just ((SemanticTokensOptions |? b)
-> Maybe (SemanticTokensOptions |? b))
-> (SemanticTokensOptions |? b)
-> Maybe (SemanticTokensOptions |? b)
forall a b. (a -> b) -> a -> b
$ SemanticTokensOptions -> SemanticTokensOptions |? b
forall a b. a -> a |? b
InL (SemanticTokensOptions -> SemanticTokensOptions |? b)
-> SemanticTokensOptions -> SemanticTokensOptions |? b
forall a b. (a -> b) -> a -> b
$ Maybe Bool
-> SemanticTokensLegend
-> Maybe (Bool |? Rec (Empty @(*)))
-> Maybe
(Bool
|? Rec ((.+) @(*) ((.==) @(*) "delta" (Maybe Bool)) (Empty @(*))))
-> SemanticTokensOptions
SemanticTokensOptions Maybe Bool
forall a. Maybe a
Nothing SemanticTokensLegend
defaultSemanticTokensLegend Maybe (Bool |? Rec (Empty @(*)))
forall {b}. Maybe (Bool |? b)
semanticTokenRangeProvider Maybe
(Bool
|? Rec ((.+) @(*) ((.==) @(*) "delta" (Maybe Bool)) (Empty @(*))))
Maybe
(Bool
|? Rec
('R
@(*)
((':)
@(LT (*)) ((':->) @(*) "delta" (Maybe Bool)) ('[] @(LT (*))))))
forall {a}.
Maybe
(a
|? Rec
('R
@(*)
((':)
@(LT (*)) ((':->) @(*) "delta" (Maybe Bool)) ('[] @(LT (*))))))
semanticTokenFullProvider
semanticTokenRangeProvider :: Maybe (Bool |? b)
semanticTokenRangeProvider
| SClientMethod @'Request 'Method_TextDocumentSemanticTokensRange
-> Bool
forall {t :: MessageKind} (m :: Method 'ClientToServer t).
SClientMethod @t m -> Bool
supported_b SClientMethod @'Request 'Method_TextDocumentSemanticTokensRange
SMethod_TextDocumentSemanticTokensRange = (Bool |? b) -> Maybe (Bool |? b)
forall a. a -> Maybe a
Just ((Bool |? b) -> Maybe (Bool |? b))
-> (Bool |? b) -> Maybe (Bool |? b)
forall a b. (a -> b) -> a -> b
$ Bool -> Bool |? b
forall a b. a -> a |? b
InL Bool
True
| Bool
otherwise = Maybe (Bool |? b)
forall a. Maybe a
Nothing
semanticTokenFullProvider :: Maybe
(a
|? Rec
('R
@(*)
((':)
@(LT (*)) ((':->) @(*) "delta" (Maybe Bool)) ('[] @(LT (*))))))
semanticTokenFullProvider
| SClientMethod @'Request 'Method_TextDocumentSemanticTokensFull
-> Bool
forall {t :: MessageKind} (m :: Method 'ClientToServer t).
SClientMethod @t m -> Bool
supported_b SClientMethod @'Request 'Method_TextDocumentSemanticTokensFull
SMethod_TextDocumentSemanticTokensFull = (a
|? Rec
('R
@(*)
((':)
@(LT (*)) ((':->) @(*) "delta" (Maybe Bool)) ('[] @(LT (*))))))
-> Maybe
(a
|? Rec
('R
@(*)
((':)
@(LT (*)) ((':->) @(*) "delta" (Maybe Bool)) ('[] @(LT (*))))))
forall a. a -> Maybe a
Just ((a
|? Rec
('R
@(*)
((':)
@(LT (*)) ((':->) @(*) "delta" (Maybe Bool)) ('[] @(LT (*))))))
-> Maybe
(a
|? Rec
('R
@(*)
((':)
@(LT (*)) ((':->) @(*) "delta" (Maybe Bool)) ('[] @(LT (*)))))))
-> (a
|? Rec
('R
@(*)
((':)
@(LT (*)) ((':->) @(*) "delta" (Maybe Bool)) ('[] @(LT (*))))))
-> Maybe
(a
|? Rec
('R
@(*)
((':)
@(LT (*)) ((':->) @(*) "delta" (Maybe Bool)) ('[] @(LT (*))))))
forall a b. (a -> b) -> a -> b
$ Rec
('R
@(*)
((':)
@(LT (*)) ((':->) @(*) "delta" (Maybe Bool)) ('[] @(LT (*)))))
-> a
|? Rec
('R
@(*)
((':)
@(LT (*)) ((':->) @(*) "delta" (Maybe Bool)) ('[] @(LT (*)))))
forall a b. b -> a |? b
InR (Rec
('R
@(*)
((':)
@(LT (*)) ((':->) @(*) "delta" (Maybe Bool)) ('[] @(LT (*)))))
-> a
|? Rec
('R
@(*)
((':)
@(LT (*)) ((':->) @(*) "delta" (Maybe Bool)) ('[] @(LT (*))))))
-> Rec
('R
@(*)
((':)
@(LT (*)) ((':->) @(*) "delta" (Maybe Bool)) ('[] @(LT (*)))))
-> a
|? Rec
('R
@(*)
((':)
@(LT (*)) ((':->) @(*) "delta" (Maybe Bool)) ('[] @(LT (*)))))
forall a b. (a -> b) -> a -> b
$ Label "delta"
#delta Label "delta"
-> Maybe Bool -> Rec ((.==) @(*) "delta" (Maybe Bool))
forall (l :: Symbol) a.
KnownSymbol l =>
Label l -> a -> Rec ((.==) @(*) l a)
.== SClientMethod @'Request 'Method_TextDocumentSemanticTokensFullDelta
-> Maybe Bool
forall {t :: MessageKind} (m :: Method 'ClientToServer t).
SClientMethod @t m -> Maybe Bool
supported SClientMethod @'Request 'Method_TextDocumentSemanticTokensFullDelta
SMethod_TextDocumentSemanticTokensFullDelta
| Bool
otherwise = Maybe
(a
|? Rec
('R
@(*)
((':)
@(LT (*)) ((':->) @(*) "delta" (Maybe Bool)) ('[] @(LT (*))))))
forall a. Maybe a
Nothing
sync :: Maybe (TextDocumentSyncOptions |? TextDocumentSyncKind)
sync = case Options -> Maybe TextDocumentSyncOptions
optTextDocumentSync Options
o of
Just TextDocumentSyncOptions
x -> (TextDocumentSyncOptions |? TextDocumentSyncKind)
-> Maybe (TextDocumentSyncOptions |? TextDocumentSyncKind)
forall a. a -> Maybe a
Just (TextDocumentSyncOptions
-> TextDocumentSyncOptions |? TextDocumentSyncKind
forall a b. a -> a |? b
InL TextDocumentSyncOptions
x)
Maybe TextDocumentSyncOptions
Nothing -> Maybe (TextDocumentSyncOptions |? TextDocumentSyncKind)
forall a. Maybe a
Nothing
workspace :: Rec
((.+)
@(*)
('R
@(*)
((':)
@(LT (*))
((':->)
@(*) "workspaceFolders" (Maybe WorkspaceFoldersServerCapabilities))
('[] @(LT (*)))))
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "fileOperations" (Maybe a))
('[] @(LT (*))))))
workspace = Label "workspaceFolders"
#workspaceFolders Label "workspaceFolders"
-> Maybe WorkspaceFoldersServerCapabilities
-> Rec
((.==)
@(*) "workspaceFolders" (Maybe WorkspaceFoldersServerCapabilities))
forall (l :: Symbol) a.
KnownSymbol l =>
Label l -> a -> Rec ((.==) @(*) l a)
.== Maybe WorkspaceFoldersServerCapabilities
workspaceFolder Rec
('R
@(*)
((':)
@(LT (*))
((':->)
@(*) "workspaceFolders" (Maybe WorkspaceFoldersServerCapabilities))
('[] @(LT (*)))))
-> Rec
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "fileOperations" (Maybe a))
('[] @(LT (*)))))
-> Rec
((.+)
@(*)
('R
@(*)
((':)
@(LT (*))
((':->)
@(*) "workspaceFolders" (Maybe WorkspaceFoldersServerCapabilities))
('[] @(LT (*)))))
('R
@(*)
((':)
@(LT (*))
((':->) @(*) "fileOperations" (Maybe a))
('[] @(LT (*))))))
forall (l :: Row (*)) (r :: Row (*)).
FreeForall @(*) l =>
Rec l -> Rec r -> Rec ((.+) @(*) l r)
.+ Label "fileOperations"
#fileOperations Label "fileOperations"
-> Maybe a -> Rec ((.==) @(*) "fileOperations" (Maybe a))
forall (l :: Symbol) a.
KnownSymbol l =>
Label l -> a -> Rec ((.==) @(*) l a)
.== Maybe a
forall a. Maybe a
Nothing
workspaceFolder :: Maybe WorkspaceFoldersServerCapabilities
workspaceFolder =
SClientMethod
@'Notification 'Method_WorkspaceDidChangeWorkspaceFolders
-> WorkspaceFoldersServerCapabilities
-> Maybe WorkspaceFoldersServerCapabilities
forall {t :: MessageKind} {m :: Method 'ClientToServer t} {a}.
SClientMethod @t m -> a -> Maybe a
supported' SClientMethod
@'Notification 'Method_WorkspaceDidChangeWorkspaceFolders
SMethod_WorkspaceDidChangeWorkspaceFolders (WorkspaceFoldersServerCapabilities
-> Maybe WorkspaceFoldersServerCapabilities)
-> WorkspaceFoldersServerCapabilities
-> Maybe WorkspaceFoldersServerCapabilities
forall a b. (a -> b) -> a -> b
$
Maybe Bool
-> Maybe (Text |? Bool) -> WorkspaceFoldersServerCapabilities
WorkspaceFoldersServerCapabilities (Bool -> Maybe Bool
forall a. a -> Maybe a
Just Bool
True) ((Text |? Bool) -> Maybe (Text |? Bool)
forall a. a -> Maybe a
Just (Bool -> Text |? Bool
forall a b. b -> a |? b
InR Bool
True))
diagnosticProvider :: Maybe (DiagnosticOptions |? b)
diagnosticProvider =
SClientMethod @'Request 'Method_TextDocumentDiagnostic
-> (DiagnosticOptions |? b) -> Maybe (DiagnosticOptions |? b)
forall {t :: MessageKind} {m :: Method 'ClientToServer t} {a}.
SClientMethod @t m -> a -> Maybe a
supported' SClientMethod @'Request 'Method_TextDocumentDiagnostic
SMethod_TextDocumentDiagnostic ((DiagnosticOptions |? b) -> Maybe (DiagnosticOptions |? b))
-> (DiagnosticOptions |? b) -> Maybe (DiagnosticOptions |? b)
forall a b. (a -> b) -> a -> b
$
DiagnosticOptions -> DiagnosticOptions |? b
forall a b. a -> a |? b
InL (DiagnosticOptions -> DiagnosticOptions |? b)
-> DiagnosticOptions -> DiagnosticOptions |? b
forall a b. (a -> b) -> a -> b
$
DiagnosticOptions
{ $sel:_workDoneProgress:DiagnosticOptions :: Maybe Bool
_workDoneProgress = Maybe Bool
forall a. Maybe a
Nothing
, $sel:_identifier:DiagnosticOptions :: Maybe Text
_identifier = Maybe Text
forall a. Maybe a
Nothing
,
$sel:_interFileDependencies:DiagnosticOptions :: Bool
_interFileDependencies = Bool
True
, $sel:_workspaceDiagnostics:DiagnosticOptions :: Bool
_workspaceDiagnostics = SClientMethod @'Request 'Method_WorkspaceDiagnostic -> Bool
forall {t :: MessageKind} (m :: Method 'ClientToServer t).
SClientMethod @t m -> Bool
supported_b SClientMethod @'Request 'Method_WorkspaceDiagnostic
SMethod_WorkspaceDiagnostic
}
handle :: (m ~ LspM config) => LogAction m (WithSeverity LspProcessingLog) -> SClientMethod meth -> TClientMessage meth -> m ()
handle :: forall {t :: MessageKind} (m :: * -> *) config
(meth :: Method 'ClientToServer t).
((m :: (* -> *)) ~ (LspM config :: (* -> *))) =>
LogAction m (WithSeverity LspProcessingLog)
-> SClientMethod @t meth -> TClientMessage @t meth -> m ()
handle LogAction m (WithSeverity LspProcessingLog)
logger SClientMethod @t meth
m TClientMessage @t meth
msg =
case SClientMethod @t meth
m of
SClientMethod @t meth
SMethod_WorkspaceDidChangeWorkspaceFolders -> LogAction m (WithSeverity LspProcessingLog)
-> Maybe (TClientMessage @t meth -> m ())
-> SClientMethod @t meth
-> TClientMessage @t meth
-> m ()
forall (m :: * -> *) (t :: MessageKind)
(meth :: Method 'ClientToServer t) config.
((m :: (* -> *)) ~ (LspM config :: (* -> *))) =>
LogAction m (WithSeverity LspProcessingLog)
-> Maybe (TClientMessage @t meth -> m ())
-> SClientMethod @t meth
-> TClientMessage @t meth
-> m ()
handle' LogAction m (WithSeverity LspProcessingLog)
logger ((TNotificationMessage
@'ClientToServer 'Method_WorkspaceDidChangeWorkspaceFolders
-> LspT config IO ())
-> Maybe
(TNotificationMessage
@'ClientToServer 'Method_WorkspaceDidChangeWorkspaceFolders
-> LspT config IO ())
forall a. a -> Maybe a
Just TMessage
@'ClientToServer
@'Notification
'Method_WorkspaceDidChangeWorkspaceFolders
-> LspT config IO ()
TNotificationMessage
@'ClientToServer 'Method_WorkspaceDidChangeWorkspaceFolders
-> LspT config IO ()
forall config.
TMessage
@'ClientToServer
@'Notification
'Method_WorkspaceDidChangeWorkspaceFolders
-> LspM config ()
updateWorkspaceFolders) SClientMethod @t meth
m TClientMessage @t meth
msg
SClientMethod @t meth
SMethod_WorkspaceDidChangeConfiguration -> LogAction m (WithSeverity LspProcessingLog)
-> Maybe (TClientMessage @t meth -> m ())
-> SClientMethod @t meth
-> TClientMessage @t meth
-> m ()
forall (m :: * -> *) (t :: MessageKind)
(meth :: Method 'ClientToServer t) config.
((m :: (* -> *)) ~ (LspM config :: (* -> *))) =>
LogAction m (WithSeverity LspProcessingLog)
-> Maybe (TClientMessage @t meth -> m ())
-> SClientMethod @t meth
-> TClientMessage @t meth
-> m ()
handle' LogAction m (WithSeverity LspProcessingLog)
logger ((TClientMessage @t meth -> m ())
-> Maybe (TClientMessage @t meth -> m ())
forall a. a -> Maybe a
Just ((TClientMessage @t meth -> m ())
-> Maybe (TClientMessage @t meth -> m ()))
-> (TClientMessage @t meth -> m ())
-> Maybe (TClientMessage @t meth -> m ())
forall a b. (a -> b) -> a -> b
$ LogAction m (WithSeverity LspProcessingLog)
-> TMessage
@'ClientToServer
@'Notification
'Method_WorkspaceDidChangeConfiguration
-> m ()
forall (m :: * -> *) config.
((m :: (* -> *)) ~ (LspM config :: (* -> *))) =>
LogAction m (WithSeverity LspProcessingLog)
-> TMessage
@'ClientToServer
@'Notification
'Method_WorkspaceDidChangeConfiguration
-> m ()
handleDidChangeConfiguration LogAction m (WithSeverity LspProcessingLog)
logger) SClientMethod @t meth
m TClientMessage @t meth
msg
SClientMethod @t meth
SMethod_Initialized -> LogAction m (WithSeverity LspProcessingLog)
-> Maybe (TClientMessage @t meth -> m ())
-> SClientMethod @t meth
-> TClientMessage @t meth
-> m ()
forall (m :: * -> *) (t :: MessageKind)
(meth :: Method 'ClientToServer t) config.
((m :: (* -> *)) ~ (LspM config :: (* -> *))) =>
LogAction m (WithSeverity LspProcessingLog)
-> Maybe (TClientMessage @t meth -> m ())
-> SClientMethod @t meth
-> TClientMessage @t meth
-> m ()
handle' LogAction m (WithSeverity LspProcessingLog)
logger ((TClientMessage @t meth -> m ())
-> Maybe (TClientMessage @t meth -> m ())
forall a. a -> Maybe a
Just ((TClientMessage @t meth -> m ())
-> Maybe (TClientMessage @t meth -> m ()))
-> (TClientMessage @t meth -> m ())
-> Maybe (TClientMessage @t meth -> m ())
forall a b. (a -> b) -> a -> b
$ \TClientMessage @t meth
_ -> LogAction m (WithSeverity LspCoreLog) -> m ()
forall (m :: * -> *) config.
((m :: (* -> *)) ~ (LspM config :: (* -> *))) =>
LogAction m (WithSeverity LspCoreLog) -> m ()
requestConfigUpdate ((WithSeverity LspCoreLog -> WithSeverity LspProcessingLog)
-> LogAction m (WithSeverity LspProcessingLog)
-> LogAction m (WithSeverity LspCoreLog)
forall a b (m :: * -> *).
(a -> b) -> LogAction m b -> LogAction m a
cmap ((LspCoreLog -> LspProcessingLog)
-> WithSeverity LspCoreLog -> WithSeverity LspProcessingLog
forall a b. (a -> b) -> WithSeverity a -> WithSeverity b
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap LspCoreLog -> LspProcessingLog
LspCore) LogAction m (WithSeverity LspProcessingLog)
logger)) SClientMethod @t meth
m TClientMessage @t meth
msg
SClientMethod @t meth
SMethod_TextDocumentDidOpen -> LogAction m (WithSeverity LspProcessingLog)
-> Maybe (TClientMessage @t meth -> m ())
-> SClientMethod @t meth
-> TClientMessage @t meth
-> m ()
forall (m :: * -> *) (t :: MessageKind)
(meth :: Method 'ClientToServer t) config.
((m :: (* -> *)) ~ (LspM config :: (* -> *))) =>
LogAction m (WithSeverity LspProcessingLog)
-> Maybe (TClientMessage @t meth -> m ())
-> SClientMethod @t meth
-> TClientMessage @t meth
-> m ()
handle' LogAction m (WithSeverity LspProcessingLog)
logger ((TClientMessage @t meth -> m ())
-> Maybe (TClientMessage @t meth -> m ())
forall a. a -> Maybe a
Just ((TClientMessage @t meth -> m ())
-> Maybe (TClientMessage @t meth -> m ()))
-> (TClientMessage @t meth -> m ())
-> Maybe (TClientMessage @t meth -> m ())
forall a b. (a -> b) -> a -> b
$ LogAction m (WithSeverity LspProcessingLog)
-> (LogAction
(WriterT [WithSeverity VfsLog] (State VFS)) (WithSeverity VfsLog)
-> TNotificationMessage
@'ClientToServer 'Method_TextDocumentDidOpen
-> WriterT [WithSeverity VfsLog] (State VFS) ())
-> TNotificationMessage
@'ClientToServer 'Method_TextDocumentDidOpen
-> m ()
forall (m :: * -> *) (n :: * -> *) a config.
((m :: (* -> *)) ~ (LspM config :: (* -> *)),
(n :: (* -> *))
~ (WriterT [WithSeverity VfsLog] (State VFS) :: (* -> *))) =>
LogAction m (WithSeverity LspProcessingLog)
-> (LogAction n (WithSeverity VfsLog) -> a -> n ()) -> a -> m ()
vfsFunc LogAction m (WithSeverity LspProcessingLog)
logger LogAction
(WriterT [WithSeverity VfsLog] (State VFS)) (WithSeverity VfsLog)
-> TMessage
@'ClientToServer @'Notification 'Method_TextDocumentDidOpen
-> WriterT [WithSeverity VfsLog] (State VFS) ()
LogAction
(WriterT [WithSeverity VfsLog] (State VFS)) (WithSeverity VfsLog)
-> TNotificationMessage
@'ClientToServer 'Method_TextDocumentDidOpen
-> WriterT [WithSeverity VfsLog] (State VFS) ()
forall (m :: * -> *).
MonadState VFS m =>
LogAction m (WithSeverity VfsLog)
-> TMessage
@'ClientToServer @'Notification 'Method_TextDocumentDidOpen
-> m ()
openVFS) SClientMethod @t meth
m TClientMessage @t meth
msg
SClientMethod @t meth
SMethod_TextDocumentDidChange -> LogAction m (WithSeverity LspProcessingLog)
-> Maybe (TClientMessage @t meth -> m ())
-> SClientMethod @t meth
-> TClientMessage @t meth
-> m ()
forall (m :: * -> *) (t :: MessageKind)
(meth :: Method 'ClientToServer t) config.
((m :: (* -> *)) ~ (LspM config :: (* -> *))) =>
LogAction m (WithSeverity LspProcessingLog)
-> Maybe (TClientMessage @t meth -> m ())
-> SClientMethod @t meth
-> TClientMessage @t meth
-> m ()
handle' LogAction m (WithSeverity LspProcessingLog)
logger ((TClientMessage @t meth -> m ())
-> Maybe (TClientMessage @t meth -> m ())
forall a. a -> Maybe a
Just ((TClientMessage @t meth -> m ())
-> Maybe (TClientMessage @t meth -> m ()))
-> (TClientMessage @t meth -> m ())
-> Maybe (TClientMessage @t meth -> m ())
forall a b. (a -> b) -> a -> b
$ LogAction m (WithSeverity LspProcessingLog)
-> (LogAction
(WriterT [WithSeverity VfsLog] (State VFS)) (WithSeverity VfsLog)
-> TNotificationMessage
@'ClientToServer 'Method_TextDocumentDidChange
-> WriterT [WithSeverity VfsLog] (State VFS) ())
-> TNotificationMessage
@'ClientToServer 'Method_TextDocumentDidChange
-> m ()
forall (m :: * -> *) (n :: * -> *) a config.
((m :: (* -> *)) ~ (LspM config :: (* -> *)),
(n :: (* -> *))
~ (WriterT [WithSeverity VfsLog] (State VFS) :: (* -> *))) =>
LogAction m (WithSeverity LspProcessingLog)
-> (LogAction n (WithSeverity VfsLog) -> a -> n ()) -> a -> m ()
vfsFunc LogAction m (WithSeverity LspProcessingLog)
logger LogAction
(WriterT [WithSeverity VfsLog] (State VFS)) (WithSeverity VfsLog)
-> TMessage
@'ClientToServer @'Notification 'Method_TextDocumentDidChange
-> WriterT [WithSeverity VfsLog] (State VFS) ()
LogAction
(WriterT [WithSeverity VfsLog] (State VFS)) (WithSeverity VfsLog)
-> TNotificationMessage
@'ClientToServer 'Method_TextDocumentDidChange
-> WriterT [WithSeverity VfsLog] (State VFS) ()
forall (m :: * -> *).
MonadState VFS m =>
LogAction m (WithSeverity VfsLog)
-> TMessage
@'ClientToServer @'Notification 'Method_TextDocumentDidChange
-> m ()
changeFromClientVFS) SClientMethod @t meth
m TClientMessage @t meth
msg
SClientMethod @t meth
SMethod_TextDocumentDidClose -> LogAction m (WithSeverity LspProcessingLog)
-> Maybe (TClientMessage @t meth -> m ())
-> SClientMethod @t meth
-> TClientMessage @t meth
-> m ()
forall (m :: * -> *) (t :: MessageKind)
(meth :: Method 'ClientToServer t) config.
((m :: (* -> *)) ~ (LspM config :: (* -> *))) =>
LogAction m (WithSeverity LspProcessingLog)
-> Maybe (TClientMessage @t meth -> m ())
-> SClientMethod @t meth
-> TClientMessage @t meth
-> m ()
handle' LogAction m (WithSeverity LspProcessingLog)
logger ((TClientMessage @t meth -> m ())
-> Maybe (TClientMessage @t meth -> m ())
forall a. a -> Maybe a
Just ((TClientMessage @t meth -> m ())
-> Maybe (TClientMessage @t meth -> m ()))
-> (TClientMessage @t meth -> m ())
-> Maybe (TClientMessage @t meth -> m ())
forall a b. (a -> b) -> a -> b
$ LogAction m (WithSeverity LspProcessingLog)
-> (LogAction
(WriterT [WithSeverity VfsLog] (State VFS)) (WithSeverity VfsLog)
-> TNotificationMessage
@'ClientToServer 'Method_TextDocumentDidClose
-> WriterT [WithSeverity VfsLog] (State VFS) ())
-> TNotificationMessage
@'ClientToServer 'Method_TextDocumentDidClose
-> m ()
forall (m :: * -> *) (n :: * -> *) a config.
((m :: (* -> *)) ~ (LspM config :: (* -> *)),
(n :: (* -> *))
~ (WriterT [WithSeverity VfsLog] (State VFS) :: (* -> *))) =>
LogAction m (WithSeverity LspProcessingLog)
-> (LogAction n (WithSeverity VfsLog) -> a -> n ()) -> a -> m ()
vfsFunc LogAction m (WithSeverity LspProcessingLog)
logger LogAction
(WriterT [WithSeverity VfsLog] (State VFS)) (WithSeverity VfsLog)
-> TMessage
@'ClientToServer @'Notification 'Method_TextDocumentDidClose
-> WriterT [WithSeverity VfsLog] (State VFS) ()
LogAction
(WriterT [WithSeverity VfsLog] (State VFS)) (WithSeverity VfsLog)
-> TNotificationMessage
@'ClientToServer 'Method_TextDocumentDidClose
-> WriterT [WithSeverity VfsLog] (State VFS) ()
forall (m :: * -> *).
MonadState VFS m =>
LogAction m (WithSeverity VfsLog)
-> TMessage
@'ClientToServer @'Notification 'Method_TextDocumentDidClose
-> m ()
closeVFS) SClientMethod @t meth
m TClientMessage @t meth
msg
SClientMethod @t meth
SMethod_WindowWorkDoneProgressCancel -> LogAction m (WithSeverity LspProcessingLog)
-> Maybe (TClientMessage @t meth -> m ())
-> SClientMethod @t meth
-> TClientMessage @t meth
-> m ()
forall (m :: * -> *) (t :: MessageKind)
(meth :: Method 'ClientToServer t) config.
((m :: (* -> *)) ~ (LspM config :: (* -> *))) =>
LogAction m (WithSeverity LspProcessingLog)
-> Maybe (TClientMessage @t meth -> m ())
-> SClientMethod @t meth
-> TClientMessage @t meth
-> m ()
handle' LogAction m (WithSeverity LspProcessingLog)
logger ((TClientMessage @t meth -> m ())
-> Maybe (TClientMessage @t meth -> m ())
forall a. a -> Maybe a
Just ((TClientMessage @t meth -> m ())
-> Maybe (TClientMessage @t meth -> m ()))
-> (TClientMessage @t meth -> m ())
-> Maybe (TClientMessage @t meth -> m ())
forall a b. (a -> b) -> a -> b
$ LogAction m (WithSeverity LspProcessingLog)
-> TMessage
@'ClientToServer
@'Notification
'Method_WindowWorkDoneProgressCancel
-> m ()
forall (m :: * -> *) config.
((m :: (* -> *)) ~ (LspM config :: (* -> *))) =>
LogAction m (WithSeverity LspProcessingLog)
-> TMessage
@'ClientToServer
@'Notification
'Method_WindowWorkDoneProgressCancel
-> m ()
progressCancelHandler LogAction m (WithSeverity LspProcessingLog)
logger) SClientMethod @t meth
m TClientMessage @t meth
msg
SClientMethod @t meth
_ -> LogAction m (WithSeverity LspProcessingLog)
-> Maybe (TClientMessage @t meth -> m ())
-> SClientMethod @t meth
-> TClientMessage @t meth
-> m ()
forall (m :: * -> *) (t :: MessageKind)
(meth :: Method 'ClientToServer t) config.
((m :: (* -> *)) ~ (LspM config :: (* -> *))) =>
LogAction m (WithSeverity LspProcessingLog)
-> Maybe (TClientMessage @t meth -> m ())
-> SClientMethod @t meth
-> TClientMessage @t meth
-> m ()
handle' LogAction m (WithSeverity LspProcessingLog)
logger Maybe (TClientMessage @t meth -> m ())
Maybe (TClientMessage @t meth -> LspT config IO ())
forall a. Maybe a
Nothing SClientMethod @t meth
m TClientMessage @t meth
msg
handle' ::
forall m t (meth :: Method ClientToServer t) config.
(m ~ LspM config) =>
LogAction m (WithSeverity LspProcessingLog) ->
Maybe (TClientMessage meth -> m ()) ->
SClientMethod meth ->
TClientMessage meth ->
m ()
handle' :: forall (m :: * -> *) (t :: MessageKind)
(meth :: Method 'ClientToServer t) config.
((m :: (* -> *)) ~ (LspM config :: (* -> *))) =>
LogAction m (WithSeverity LspProcessingLog)
-> Maybe (TClientMessage @t meth -> m ())
-> SClientMethod @t meth
-> TClientMessage @t meth
-> m ()
handle' LogAction m (WithSeverity LspProcessingLog)
logger Maybe (TClientMessage @t meth -> m ())
mAction SClientMethod @t meth
m TClientMessage @t meth
msg = do
m ()
-> ((TClientMessage @t meth -> m ()) -> m ())
-> Maybe (TClientMessage @t meth -> m ())
-> m ()
forall b a. b -> (a -> b) -> Maybe a -> b
maybe (() -> m ()
forall a. a -> m a
forall (m :: * -> *) a. Monad m => a -> m a
return ()) (\TClientMessage @t meth -> m ()
f -> TClientMessage @t meth -> m ()
f TClientMessage @t meth
msg) Maybe (TClientMessage @t meth -> m ())
mAction
RegistrationMap 'Request
dynReqHandlers <- (LanguageContextState config -> TVar (RegistrationMap 'Request))
-> m (RegistrationMap 'Request)
forall config (m :: * -> *) a.
MonadLsp config m =>
(LanguageContextState config -> TVar a) -> m a
getsState LanguageContextState config -> TVar (RegistrationMap 'Request)
forall config.
LanguageContextState config -> TVar (RegistrationMap 'Request)
resRegistrationsReq
RegistrationMap 'Notification
dynNotHandlers <- (LanguageContextState config
-> TVar (RegistrationMap 'Notification))
-> m (RegistrationMap 'Notification)
forall config (m :: * -> *) a.
MonadLsp config m =>
(LanguageContextState config -> TVar a) -> m a
getsState LanguageContextState config -> TVar (RegistrationMap 'Notification)
forall config.
LanguageContextState config -> TVar (RegistrationMap 'Notification)
resRegistrationsNot
LanguageContextEnv config
env <- m (LanguageContextEnv config)
forall config (m :: * -> *).
MonadLsp config m =>
m (LanguageContextEnv config)
getLspEnv
let Handlers{SMethodMap
@'ClientToServer @'Request (ClientMessageHandler IO 'Request)
reqHandlers :: forall (m :: * -> *).
Handlers m
-> SMethodMap
@'ClientToServer @'Request (ClientMessageHandler m 'Request)
reqHandlers :: SMethodMap
@'ClientToServer @'Request (ClientMessageHandler IO 'Request)
reqHandlers, SMethodMap
@'ClientToServer
@'Notification
(ClientMessageHandler IO 'Notification)
notHandlers :: forall (m :: * -> *).
Handlers m
-> SMethodMap
@'ClientToServer
@'Notification
(ClientMessageHandler m 'Notification)
notHandlers :: SMethodMap
@'ClientToServer
@'Notification
(ClientMessageHandler IO 'Notification)
notHandlers} = LanguageContextEnv config -> Handlers IO
forall config. LanguageContextEnv config -> Handlers IO
resHandlers LanguageContextEnv config
env
let mkRspCb :: TRequestMessage (m1 :: Method ClientToServer Request) -> Either ResponseError (MessageResult m1) -> IO ()
mkRspCb :: forall (m1 :: Method 'ClientToServer 'Request).
TRequestMessage @'ClientToServer m1
-> Either
ResponseError (MessageResult @'ClientToServer @'Request m1)
-> IO ()
mkRspCb TRequestMessage @'ClientToServer m1
req (Left ResponseError
err) =
LanguageContextEnv config -> LspT config IO () -> IO ()
forall config (m :: * -> *) a.
LanguageContextEnv config -> LspT config m a -> m a
runLspT LanguageContextEnv config
env (LspT config IO () -> IO ()) -> LspT config IO () -> IO ()
forall a b. (a -> b) -> a -> b
$
FromServerMessage -> LspT config IO ()
forall config (m :: * -> *).
MonadLsp config m =>
FromServerMessage -> m ()
sendToClient (FromServerMessage -> LspT config IO ())
-> FromServerMessage -> LspT config IO ()
forall a b. (a -> b) -> a -> b
$
SMethod @'ClientToServer @'Request m1
-> TResponseMessage @'ClientToServer m1 -> FromServerMessage
forall (m :: Method 'ClientToServer 'Request)
(a :: Method 'ClientToServer 'Request -> *).
a m -> TResponseMessage @'ClientToServer m -> FromServerMessage' a
FromServerRsp (TRequestMessage @'ClientToServer m1
req TRequestMessage @'ClientToServer m1
-> Getting
(SMethod @'ClientToServer @'Request m1)
(TRequestMessage @'ClientToServer m1)
(SMethod @'ClientToServer @'Request m1)
-> SMethod @'ClientToServer @'Request m1
forall s a. s -> Getting a s a -> a
^. Getting
(SMethod @'ClientToServer @'Request m1)
(TRequestMessage @'ClientToServer m1)
(SMethod @'ClientToServer @'Request m1)
forall s a. HasMethod s a => Lens' s a
Lens'
(TRequestMessage @'ClientToServer m1)
(SMethod @'ClientToServer @'Request m1)
L.method) (TResponseMessage @'ClientToServer m1 -> FromServerMessage)
-> TResponseMessage @'ClientToServer m1 -> FromServerMessage
forall a b. (a -> b) -> a -> b
$
Text
-> Maybe (LspId @'ClientToServer m1)
-> Either
ResponseError (MessageResult @'ClientToServer @'Request m1)
-> TResponseMessage @'ClientToServer m1
forall (f :: MessageDirection) (m :: Method f 'Request).
Text
-> Maybe (LspId @f m)
-> Either ResponseError (MessageResult @f @'Request m)
-> TResponseMessage @f m
TResponseMessage Text
"2.0" (LspId @'ClientToServer m1 -> Maybe (LspId @'ClientToServer m1)
forall a. a -> Maybe a
Just (TRequestMessage @'ClientToServer m1
req TRequestMessage @'ClientToServer m1
-> Getting
(LspId @'ClientToServer m1)
(TRequestMessage @'ClientToServer m1)
(LspId @'ClientToServer m1)
-> LspId @'ClientToServer m1
forall s a. s -> Getting a s a -> a
^. Getting
(LspId @'ClientToServer m1)
(TRequestMessage @'ClientToServer m1)
(LspId @'ClientToServer m1)
forall s a. HasId s a => Lens' s a
Lens'
(TRequestMessage @'ClientToServer m1) (LspId @'ClientToServer m1)
L.id)) (ResponseError
-> Either
ResponseError (MessageResult @'ClientToServer @'Request m1)
forall a b. a -> Either a b
Left ResponseError
err)
mkRspCb TRequestMessage @'ClientToServer m1
req (Right MessageResult @'ClientToServer @'Request m1
rsp) =
LanguageContextEnv config -> LspT config IO () -> IO ()
forall config (m :: * -> *) a.
LanguageContextEnv config -> LspT config m a -> m a
runLspT LanguageContextEnv config
env (LspT config IO () -> IO ()) -> LspT config IO () -> IO ()
forall a b. (a -> b) -> a -> b
$
FromServerMessage -> LspT config IO ()
forall config (m :: * -> *).
MonadLsp config m =>
FromServerMessage -> m ()
sendToClient (FromServerMessage -> LspT config IO ())
-> FromServerMessage -> LspT config IO ()
forall a b. (a -> b) -> a -> b
$
SMethod @'ClientToServer @'Request m1
-> TResponseMessage @'ClientToServer m1 -> FromServerMessage
forall (m :: Method 'ClientToServer 'Request)
(a :: Method 'ClientToServer 'Request -> *).
a m -> TResponseMessage @'ClientToServer m -> FromServerMessage' a
FromServerRsp (TRequestMessage @'ClientToServer m1
req TRequestMessage @'ClientToServer m1
-> Getting
(SMethod @'ClientToServer @'Request m1)
(TRequestMessage @'ClientToServer m1)
(SMethod @'ClientToServer @'Request m1)
-> SMethod @'ClientToServer @'Request m1
forall s a. s -> Getting a s a -> a
^. Getting
(SMethod @'ClientToServer @'Request m1)
(TRequestMessage @'ClientToServer m1)
(SMethod @'ClientToServer @'Request m1)
forall s a. HasMethod s a => Lens' s a
Lens'
(TRequestMessage @'ClientToServer m1)
(SMethod @'ClientToServer @'Request m1)
L.method) (TResponseMessage @'ClientToServer m1 -> FromServerMessage)
-> TResponseMessage @'ClientToServer m1 -> FromServerMessage
forall a b. (a -> b) -> a -> b
$
Text
-> Maybe (LspId @'ClientToServer m1)
-> Either
ResponseError (MessageResult @'ClientToServer @'Request m1)
-> TResponseMessage @'ClientToServer m1
forall (f :: MessageDirection) (m :: Method f 'Request).
Text
-> Maybe (LspId @f m)
-> Either ResponseError (MessageResult @f @'Request m)
-> TResponseMessage @f m
TResponseMessage Text
"2.0" (LspId @'ClientToServer m1 -> Maybe (LspId @'ClientToServer m1)
forall a. a -> Maybe a
Just (TRequestMessage @'ClientToServer m1
req TRequestMessage @'ClientToServer m1
-> Getting
(LspId @'ClientToServer m1)
(TRequestMessage @'ClientToServer m1)
(LspId @'ClientToServer m1)
-> LspId @'ClientToServer m1
forall s a. s -> Getting a s a -> a
^. Getting
(LspId @'ClientToServer m1)
(TRequestMessage @'ClientToServer m1)
(LspId @'ClientToServer m1)
forall s a. HasId s a => Lens' s a
Lens'
(TRequestMessage @'ClientToServer m1) (LspId @'ClientToServer m1)
L.id)) (MessageResult @'ClientToServer @'Request m1
-> Either
ResponseError (MessageResult @'ClientToServer @'Request m1)
forall a b. b -> Either a b
Right MessageResult @'ClientToServer @'Request m1
rsp)
case SClientMethod @t meth -> ClientNotOrReq @t meth
forall {t :: MessageKind} (m :: Method 'ClientToServer t).
SClientMethod @t m -> ClientNotOrReq @t m
splitClientMethod SClientMethod @t meth
m of
ClientNotOrReq @t meth
IsClientNot -> case RegistrationMap t
-> SMethodMap @'ClientToServer @t (ClientMessageHandler IO t)
-> Maybe (Handler @'ClientToServer @t IO meth)
pickHandler RegistrationMap t
RegistrationMap 'Notification
dynNotHandlers SMethodMap @'ClientToServer @t (ClientMessageHandler IO t)
SMethodMap
@'ClientToServer
@'Notification
(ClientMessageHandler IO 'Notification)
notHandlers of
Just Handler @'ClientToServer @t IO meth
h -> IO () -> m ()
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO () -> m ()) -> IO () -> m ()
forall a b. (a -> b) -> a -> b
$ Handler @'ClientToServer @t IO meth
TNotificationMessage @'ClientToServer meth -> IO ()
h TClientMessage @t meth
TNotificationMessage @'ClientToServer meth
msg
Maybe (Handler @'ClientToServer @t IO meth)
Nothing
| SClientMethod @t meth
SMethod_Exit <- SClientMethod @t meth
m -> LogAction m (WithSeverity LspProcessingLog)
-> Handler @'ClientToServer @'Notification m 'Method_Exit
forall (m :: * -> *).
MonadIO m =>
LogAction m (WithSeverity LspProcessingLog)
-> Handler @'ClientToServer @'Notification m 'Method_Exit
exitNotificationHandler LogAction m (WithSeverity LspProcessingLog)
logger TClientMessage @t meth
TNotificationMessage @'ClientToServer 'Method_Exit
msg
| Bool
otherwise -> do
m ()
reportMissingHandler
ClientNotOrReq @t meth
IsClientReq -> case RegistrationMap t
-> SMethodMap @'ClientToServer @t (ClientMessageHandler IO t)
-> Maybe (Handler @'ClientToServer @t IO meth)
pickHandler RegistrationMap t
RegistrationMap 'Request
dynReqHandlers SMethodMap @'ClientToServer @t (ClientMessageHandler IO t)
SMethodMap
@'ClientToServer @'Request (ClientMessageHandler IO 'Request)
reqHandlers of
Just Handler @'ClientToServer @t IO meth
h -> IO () -> m ()
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO () -> m ()) -> IO () -> m ()
forall a b. (a -> b) -> a -> b
$ Handler @'ClientToServer @t IO meth
TRequestMessage @'ClientToServer meth
-> (Either
ResponseError (MessageResult @'ClientToServer @'Request meth)
-> IO ())
-> IO ()
h TClientMessage @t meth
TRequestMessage @'ClientToServer meth
msg (TRequestMessage @'ClientToServer meth
-> Either
ResponseError (MessageResult @'ClientToServer @'Request meth)
-> IO ()
forall (m1 :: Method 'ClientToServer 'Request).
TRequestMessage @'ClientToServer m1
-> Either
ResponseError (MessageResult @'ClientToServer @'Request m1)
-> IO ()
mkRspCb TClientMessage @t meth
TRequestMessage @'ClientToServer meth
msg)
Maybe (Handler @'ClientToServer @t IO meth)
Nothing
| SClientMethod @t meth
SMethod_Shutdown <- SClientMethod @t meth
m -> IO () -> m ()
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO () -> m ()) -> IO () -> m ()
forall a b. (a -> b) -> a -> b
$ Handler @'ClientToServer @'Request IO 'Method_Shutdown
TRequestMessage @'ClientToServer 'Method_Shutdown
-> (Either ResponseError Null -> IO ()) -> IO ()
shutdownRequestHandler TClientMessage @t meth
TRequestMessage @'ClientToServer 'Method_Shutdown
msg (TRequestMessage @'ClientToServer 'Method_Shutdown
-> Either
ResponseError
(MessageResult @'ClientToServer @'Request 'Method_Shutdown)
-> IO ()
forall (m1 :: Method 'ClientToServer 'Request).
TRequestMessage @'ClientToServer m1
-> Either
ResponseError (MessageResult @'ClientToServer @'Request m1)
-> IO ()
mkRspCb TClientMessage @t meth
TRequestMessage @'ClientToServer 'Method_Shutdown
msg)
| Bool
otherwise -> do
let errorMsg :: Text
errorMsg = String -> Text
T.pack (String -> Text) -> String -> Text
forall a b. (a -> b) -> a -> b
$ [String] -> String
unwords [String
"lsp:no handler for: ", SClientMethod @t meth -> String
forall a. Show a => a -> String
show SClientMethod @t meth
m]
err :: ResponseError
err = (LSPErrorCodes |? ErrorCodes)
-> Text -> Maybe Value -> ResponseError
ResponseError (ErrorCodes -> LSPErrorCodes |? ErrorCodes
forall a b. b -> a |? b
InR ErrorCodes
ErrorCodes_MethodNotFound) Text
errorMsg Maybe Value
forall a. Maybe a
Nothing
FromServerMessage -> m ()
forall config (m :: * -> *).
MonadLsp config m =>
FromServerMessage -> m ()
sendToClient (FromServerMessage -> m ()) -> FromServerMessage -> m ()
forall a b. (a -> b) -> a -> b
$
SMethod @'ClientToServer @'Request meth
-> TResponseMessage @'ClientToServer meth -> FromServerMessage
forall (m :: Method 'ClientToServer 'Request)
(a :: Method 'ClientToServer 'Request -> *).
a m -> TResponseMessage @'ClientToServer m -> FromServerMessage' a
FromServerRsp (TClientMessage @t meth
TRequestMessage @'ClientToServer meth
msg TRequestMessage @'ClientToServer meth
-> Getting
(SMethod @'ClientToServer @'Request meth)
(TRequestMessage @'ClientToServer meth)
(SMethod @'ClientToServer @'Request meth)
-> SMethod @'ClientToServer @'Request meth
forall s a. s -> Getting a s a -> a
^. Getting
(SMethod @'ClientToServer @'Request meth)
(TRequestMessage @'ClientToServer meth)
(SMethod @'ClientToServer @'Request meth)
forall s a. HasMethod s a => Lens' s a
Lens'
(TRequestMessage @'ClientToServer meth)
(SMethod @'ClientToServer @'Request meth)
L.method) (TResponseMessage @'ClientToServer meth -> FromServerMessage)
-> TResponseMessage @'ClientToServer meth -> FromServerMessage
forall a b. (a -> b) -> a -> b
$
Text
-> Maybe (LspId @'ClientToServer meth)
-> Either
ResponseError (MessageResult @'ClientToServer @'Request meth)
-> TResponseMessage @'ClientToServer meth
forall (f :: MessageDirection) (m :: Method f 'Request).
Text
-> Maybe (LspId @f m)
-> Either ResponseError (MessageResult @f @'Request m)
-> TResponseMessage @f m
TResponseMessage Text
"2.0" (LspId @'ClientToServer meth -> Maybe (LspId @'ClientToServer meth)
forall a. a -> Maybe a
Just (TClientMessage @t meth
TRequestMessage @'ClientToServer meth
msg TRequestMessage @'ClientToServer meth
-> Getting
(LspId @'ClientToServer meth)
(TRequestMessage @'ClientToServer meth)
(LspId @'ClientToServer meth)
-> LspId @'ClientToServer meth
forall s a. s -> Getting a s a -> a
^. Getting
(LspId @'ClientToServer meth)
(TRequestMessage @'ClientToServer meth)
(LspId @'ClientToServer meth)
forall s a. HasId s a => Lens' s a
Lens'
(TRequestMessage @'ClientToServer meth)
(LspId @'ClientToServer meth)
L.id)) (ResponseError
-> Either
ResponseError (MessageResult @'ClientToServer @'Request meth)
forall a b. a -> Either a b
Left ResponseError
err)
ClientNotOrReq @t meth
IsClientEither -> case TClientMessage @t meth
msg of
NotMess TNotificationMessage
@'ClientToServer
('Method_CustomMethod @'ClientToServer @'Notification s)
noti -> case RegistrationMap t
-> SMethodMap @'ClientToServer @t (ClientMessageHandler IO t)
-> Maybe (Handler @'ClientToServer @t IO meth)
pickHandler RegistrationMap t
RegistrationMap 'Notification
dynNotHandlers SMethodMap @'ClientToServer @t (ClientMessageHandler IO t)
SMethodMap
@'ClientToServer
@'Notification
(ClientMessageHandler IO 'Notification)
notHandlers of
Just Handler @'ClientToServer @t IO meth
h -> IO () -> m ()
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO () -> m ()) -> IO () -> m ()
forall a b. (a -> b) -> a -> b
$ Handler @'ClientToServer @t IO meth
TNotificationMessage
@'ClientToServer
('Method_CustomMethod @'ClientToServer @'Notification s)
-> IO ()
h TNotificationMessage
@'ClientToServer
('Method_CustomMethod @'ClientToServer @'Notification s)
noti
Maybe (Handler @'ClientToServer @t IO meth)
Nothing -> m ()
reportMissingHandler
ReqMess TRequestMessage
@'ClientToServer
('Method_CustomMethod @'ClientToServer @'Request s)
req -> case RegistrationMap t
-> SMethodMap @'ClientToServer @t (ClientMessageHandler IO t)
-> Maybe (Handler @'ClientToServer @t IO meth)
pickHandler RegistrationMap t
RegistrationMap 'Request
dynReqHandlers SMethodMap @'ClientToServer @t (ClientMessageHandler IO t)
SMethodMap
@'ClientToServer @'Request (ClientMessageHandler IO 'Request)
reqHandlers of
Just Handler @'ClientToServer @t IO meth
h -> IO () -> m ()
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO (IO () -> m ()) -> IO () -> m ()
forall a b. (a -> b) -> a -> b
$ Handler @'ClientToServer @t IO meth
TRequestMessage
@'ClientToServer
('Method_CustomMethod @'ClientToServer @'Request s)
-> (Either ResponseError Value -> IO ()) -> IO ()
h TRequestMessage
@'ClientToServer
('Method_CustomMethod @'ClientToServer @'Request s)
req (TRequestMessage
@'ClientToServer
('Method_CustomMethod @'ClientToServer @'Request s)
-> Either
ResponseError
(MessageResult
@'ClientToServer
@'Request
('Method_CustomMethod @'ClientToServer @'Request s))
-> IO ()
forall (m1 :: Method 'ClientToServer 'Request).
TRequestMessage @'ClientToServer m1
-> Either
ResponseError (MessageResult @'ClientToServer @'Request m1)
-> IO ()
mkRspCb TRequestMessage
@'ClientToServer
('Method_CustomMethod @'ClientToServer @'Request s)
req)
Maybe (Handler @'ClientToServer @t IO meth)
Nothing -> do
let errorMsg :: Text
errorMsg = String -> Text
T.pack (String -> Text) -> String -> Text
forall a b. (a -> b) -> a -> b
$ [String] -> String
unwords [String
"lsp:no handler for: ", SClientMethod @t meth -> String
forall a. Show a => a -> String
show SClientMethod @t meth
m]
err :: ResponseError
err = (LSPErrorCodes |? ErrorCodes)
-> Text -> Maybe Value -> ResponseError
ResponseError (ErrorCodes -> LSPErrorCodes |? ErrorCodes
forall a b. b -> a |? b
InR ErrorCodes
ErrorCodes_MethodNotFound) Text
errorMsg Maybe Value
forall a. Maybe a
Nothing
FromServerMessage -> m ()
forall config (m :: * -> *).
MonadLsp config m =>
FromServerMessage -> m ()
sendToClient (FromServerMessage -> m ()) -> FromServerMessage -> m ()
forall a b. (a -> b) -> a -> b
$
SMethod
@'ClientToServer
@'Request
('Method_CustomMethod @'ClientToServer @'Request s)
-> TResponseMessage
@'ClientToServer
('Method_CustomMethod @'ClientToServer @'Request s)
-> FromServerMessage
forall (m :: Method 'ClientToServer 'Request)
(a :: Method 'ClientToServer 'Request -> *).
a m -> TResponseMessage @'ClientToServer m -> FromServerMessage' a
FromServerRsp (TRequestMessage
@'ClientToServer
('Method_CustomMethod @'ClientToServer @'Request s)
req TRequestMessage
@'ClientToServer
('Method_CustomMethod @'ClientToServer @'Request s)
-> Getting
(SMethod
@'ClientToServer
@'Request
('Method_CustomMethod @'ClientToServer @'Request s))
(TRequestMessage
@'ClientToServer
('Method_CustomMethod @'ClientToServer @'Request s))
(SMethod
@'ClientToServer
@'Request
('Method_CustomMethod @'ClientToServer @'Request s))
-> SMethod
@'ClientToServer
@'Request
('Method_CustomMethod @'ClientToServer @'Request s)
forall s a. s -> Getting a s a -> a
^. Getting
(SMethod
@'ClientToServer
@'Request
('Method_CustomMethod @'ClientToServer @'Request s))
(TRequestMessage
@'ClientToServer
('Method_CustomMethod @'ClientToServer @'Request s))
(SMethod
@'ClientToServer
@'Request
('Method_CustomMethod @'ClientToServer @'Request s))
forall s a. HasMethod s a => Lens' s a
Lens'
(TRequestMessage
@'ClientToServer
('Method_CustomMethod @'ClientToServer @'Request s))
(SMethod
@'ClientToServer
@'Request
('Method_CustomMethod @'ClientToServer @'Request s))
L.method) (TResponseMessage
@'ClientToServer
('Method_CustomMethod @'ClientToServer @'Request s)
-> FromServerMessage)
-> TResponseMessage
@'ClientToServer
('Method_CustomMethod @'ClientToServer @'Request s)
-> FromServerMessage
forall a b. (a -> b) -> a -> b
$
Text
-> Maybe
(LspId
@'ClientToServer
('Method_CustomMethod @'ClientToServer @'Request s))
-> Either
ResponseError
(MessageResult
@'ClientToServer
@'Request
('Method_CustomMethod @'ClientToServer @'Request s))
-> TResponseMessage
@'ClientToServer
('Method_CustomMethod @'ClientToServer @'Request s)
forall (f :: MessageDirection) (m :: Method f 'Request).
Text
-> Maybe (LspId @f m)
-> Either ResponseError (MessageResult @f @'Request m)
-> TResponseMessage @f m
TResponseMessage Text
"2.0" (LspId
@'ClientToServer
('Method_CustomMethod @'ClientToServer @'Request s)
-> Maybe
(LspId
@'ClientToServer
('Method_CustomMethod @'ClientToServer @'Request s))
forall a. a -> Maybe a
Just (TRequestMessage
@'ClientToServer
('Method_CustomMethod @'ClientToServer @'Request s)
req TRequestMessage
@'ClientToServer
('Method_CustomMethod @'ClientToServer @'Request s)
-> Getting
(LspId
@'ClientToServer
('Method_CustomMethod @'ClientToServer @'Request s))
(TRequestMessage
@'ClientToServer
('Method_CustomMethod @'ClientToServer @'Request s))
(LspId
@'ClientToServer
('Method_CustomMethod @'ClientToServer @'Request s))
-> LspId
@'ClientToServer
('Method_CustomMethod @'ClientToServer @'Request s)
forall s a. s -> Getting a s a -> a
^. Getting
(LspId
@'ClientToServer
('Method_CustomMethod @'ClientToServer @'Request s))
(TRequestMessage
@'ClientToServer
('Method_CustomMethod @'ClientToServer @'Request s))
(LspId
@'ClientToServer
('Method_CustomMethod @'ClientToServer @'Request s))
forall s a. HasId s a => Lens' s a
Lens'
(TRequestMessage
@'ClientToServer
('Method_CustomMethod @'ClientToServer @'Request s))
(LspId
@'ClientToServer
('Method_CustomMethod @'ClientToServer @'Request s))
L.id)) (ResponseError
-> Either
ResponseError
(MessageResult
@'ClientToServer
@'Request
('Method_CustomMethod @'ClientToServer @'Request s))
forall a b. a -> Either a b
Left ResponseError
err)
where
pickHandler :: RegistrationMap t -> SMethodMap (ClientMessageHandler IO t) -> Maybe (Handler IO meth)
pickHandler :: RegistrationMap t
-> SMethodMap @'ClientToServer @t (ClientMessageHandler IO t)
-> Maybe (Handler @'ClientToServer @t IO meth)
pickHandler RegistrationMap t
dynHandlerMap SMethodMap @'ClientToServer @t (ClientMessageHandler IO t)
staticHandler = case (SClientMethod @t meth
-> RegistrationMap t
-> Maybe
(Product
@(Method 'ClientToServer t)
(RegistrationId @t)
(ClientMessageHandler IO t)
meth)
forall {f :: MessageDirection} {t :: MessageKind} (a :: Method f t)
(v :: Method f t -> *).
SMethod @f @t a -> SMethodMap @f @t v -> Maybe (v a)
SMethodMap.lookup SClientMethod @t meth
m RegistrationMap t
dynHandlerMap, SClientMethod @t meth
-> SMethodMap @'ClientToServer @t (ClientMessageHandler IO t)
-> Maybe (ClientMessageHandler IO t meth)
forall {f :: MessageDirection} {t :: MessageKind} (a :: Method f t)
(v :: Method f t -> *).
SMethod @f @t a -> SMethodMap @f @t v -> Maybe (v a)
SMethodMap.lookup SClientMethod @t meth
m SMethodMap @'ClientToServer @t (ClientMessageHandler IO t)
staticHandler) of
(Just (P.Pair RegistrationId @t meth
_ (ClientMessageHandler Handler @'ClientToServer @t IO meth
h)), Maybe (ClientMessageHandler IO t meth)
_) -> Handler @'ClientToServer @t IO meth
-> Maybe (Handler @'ClientToServer @t IO meth)
forall a. a -> Maybe a
Just Handler @'ClientToServer @t IO meth
h
(Maybe
(Product
@(Method 'ClientToServer t)
(RegistrationId @t)
(ClientMessageHandler IO t)
meth)
Nothing, Just (ClientMessageHandler Handler @'ClientToServer @t IO meth
h)) -> Handler @'ClientToServer @t IO meth
-> Maybe (Handler @'ClientToServer @t IO meth)
forall a. a -> Maybe a
Just Handler @'ClientToServer @t IO meth
h
(Maybe
(Product
@(Method 'ClientToServer t)
(RegistrationId @t)
(ClientMessageHandler IO t)
meth)
Nothing, Maybe (ClientMessageHandler IO t meth)
Nothing) -> Maybe (Handler @'ClientToServer @t IO meth)
forall a. Maybe a
Nothing
reportMissingHandler :: m ()
reportMissingHandler :: m ()
reportMissingHandler =
let optional :: Bool
optional = SomeMethod -> Bool
isOptionalMethod (SClientMethod @t meth -> SomeMethod
forall {f :: MessageDirection} {t :: MessageKind}
(m :: Method f t).
SMethod @f @t m -> SomeMethod
SomeMethod SClientMethod @t meth
m)
in LogAction m (WithSeverity LspProcessingLog)
logger LogAction m (WithSeverity LspProcessingLog)
-> WithSeverity LspProcessingLog -> m ()
forall (m :: * -> *) msg. LogAction m msg -> msg -> m ()
<& Bool -> SClientMethod @t meth -> LspProcessingLog
forall {t :: MessageKind} (m :: Method 'ClientToServer t).
Bool -> SClientMethod @t m -> LspProcessingLog
MissingHandler Bool
optional SClientMethod @t meth
m LspProcessingLog -> Severity -> WithSeverity LspProcessingLog
forall msg. msg -> Severity -> WithSeverity msg
`WithSeverity` if Bool
optional then Severity
Warning else Severity
Error
progressCancelHandler :: (m ~ LspM config) => LogAction m (WithSeverity LspProcessingLog) -> TMessage Method_WindowWorkDoneProgressCancel -> m ()
progressCancelHandler :: forall (m :: * -> *) config.
((m :: (* -> *)) ~ (LspM config :: (* -> *))) =>
LogAction m (WithSeverity LspProcessingLog)
-> TMessage
@'ClientToServer
@'Notification
'Method_WindowWorkDoneProgressCancel
-> m ()
progressCancelHandler LogAction m (WithSeverity LspProcessingLog)
logger (TNotificationMessage Text
_ SMethod
@'ClientToServer
@'Notification
'Method_WindowWorkDoneProgressCancel
_ (WorkDoneProgressCancelParams ProgressToken
tid)) = do
Map ProgressToken (IO ())
pdata <- (LanguageContextState config -> TVar (Map ProgressToken (IO ())))
-> m (Map ProgressToken (IO ()))
forall config (m :: * -> *) a.
MonadLsp config m =>
(LanguageContextState config -> TVar a) -> m a
getsState (ProgressData -> TVar (Map ProgressToken (IO ()))
progressCancel (ProgressData -> TVar (Map ProgressToken (IO ())))
-> (LanguageContextState config -> ProgressData)
-> LanguageContextState config
-> TVar (Map ProgressToken (IO ()))
forall b c a. (b -> c) -> (a -> b) -> a -> c
. LanguageContextState config -> ProgressData
forall config. LanguageContextState config -> ProgressData
resProgressData)
case ProgressToken -> Map ProgressToken (IO ()) -> Maybe (IO ())
forall k a. Ord k => k -> Map k a -> Maybe a
Map.lookup ProgressToken
tid Map ProgressToken (IO ())
pdata of
Maybe (IO ())
Nothing -> () -> m ()
forall a. a -> m a
forall (m :: * -> *) a. Monad m => a -> m a
return ()
Just IO ()
cancelAction -> do
LogAction m (WithSeverity LspProcessingLog)
logger LogAction m (WithSeverity LspProcessingLog)
-> WithSeverity LspProcessingLog -> m ()
forall (m :: * -> *) msg. LogAction m msg -> msg -> m ()
<& ProgressToken -> LspProcessingLog
ProgressCancel ProgressToken
tid LspProcessingLog -> Severity -> WithSeverity LspProcessingLog
forall msg. msg -> Severity -> WithSeverity msg
`WithSeverity` Severity
Debug
IO () -> m ()
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO IO ()
cancelAction
exitNotificationHandler :: (MonadIO m) => LogAction m (WithSeverity LspProcessingLog) -> Handler m Method_Exit
exitNotificationHandler :: forall (m :: * -> *).
MonadIO m =>
LogAction m (WithSeverity LspProcessingLog)
-> Handler @'ClientToServer @'Notification m 'Method_Exit
exitNotificationHandler LogAction m (WithSeverity LspProcessingLog)
logger TNotificationMessage @'ClientToServer 'Method_Exit
_ = do
LogAction m (WithSeverity LspProcessingLog)
logger LogAction m (WithSeverity LspProcessingLog)
-> WithSeverity LspProcessingLog -> m ()
forall (m :: * -> *) msg. LogAction m msg -> msg -> m ()
<& LspProcessingLog
Exiting LspProcessingLog -> Severity -> WithSeverity LspProcessingLog
forall msg. msg -> Severity -> WithSeverity msg
`WithSeverity` Severity
Info
IO () -> m ()
forall a. IO a -> m a
forall (m :: * -> *) a. MonadIO m => IO a -> m a
liftIO IO ()
forall a. IO a
exitSuccess
shutdownRequestHandler :: Handler IO Method_Shutdown
shutdownRequestHandler :: Handler @'ClientToServer @'Request IO 'Method_Shutdown
shutdownRequestHandler TRequestMessage @'ClientToServer 'Method_Shutdown
_req Either ResponseError Null -> IO ()
k = do
Either ResponseError Null -> IO ()
k (Either ResponseError Null -> IO ())
-> Either ResponseError Null -> IO ()
forall a b. (a -> b) -> a -> b
$ Null -> Either ResponseError Null
forall a b. b -> Either a b
Right Null
Null
lookForConfigSection :: T.Text -> Value -> Value
lookForConfigSection :: Text -> Value -> Value
lookForConfigSection Text
section (Object Object
o) | Just Value
s' <- Object
o Object -> Getting (Maybe Value) Object (Maybe Value) -> Maybe Value
forall s a. s -> Getting a s a -> a
^. Index Object -> Lens' Object (Maybe (IxValue Object))
forall m. At m => Index m -> Lens' m (Maybe (IxValue m))
at (String -> Index Object
forall a. IsString a => String -> a
fromString (String -> Index Object) -> String -> Index Object
forall a b. (a -> b) -> a -> b
$ Text -> String
T.unpack Text
section) = Value
s'
lookForConfigSection Text
_ Value
o = Value
o
handleDidChangeConfiguration :: (m ~ LspM config) => LogAction m (WithSeverity LspProcessingLog) -> TMessage Method_WorkspaceDidChangeConfiguration -> m ()
handleDidChangeConfiguration :: forall (m :: * -> *) config.
((m :: (* -> *)) ~ (LspM config :: (* -> *))) =>
LogAction m (WithSeverity LspProcessingLog)
-> TMessage
@'ClientToServer
@'Notification
'Method_WorkspaceDidChangeConfiguration
-> m ()
handleDidChangeConfiguration LogAction m (WithSeverity LspProcessingLog)
logger TMessage
@'ClientToServer
@'Notification
'Method_WorkspaceDidChangeConfiguration
req = do
Text
section <- ReaderT (LanguageContextEnv config) IO Text -> LspT config IO Text
forall config (m :: * -> *) a.
ReaderT (LanguageContextEnv config) m a -> LspT config m a
LspT (ReaderT (LanguageContextEnv config) IO Text
-> LspT config IO Text)
-> ReaderT (LanguageContextEnv config) IO Text
-> LspT config IO Text
forall a b. (a -> b) -> a -> b
$ (LanguageContextEnv config -> Text)
-> ReaderT (LanguageContextEnv config) IO Text
forall r (m :: * -> *) a. MonadReader r m => (r -> a) -> m a
asks LanguageContextEnv config -> Text
forall config. LanguageContextEnv config -> Text
resConfigSection
LogAction m (WithSeverity LspCoreLog) -> Value -> m ()
forall (m :: * -> *) config.
((m :: (* -> *)) ~ (LspM config :: (* -> *))) =>
LogAction m (WithSeverity LspCoreLog) -> Value -> m ()
tryChangeConfig ((WithSeverity LspCoreLog -> WithSeverity LspProcessingLog)
-> LogAction m (WithSeverity LspProcessingLog)
-> LogAction m (WithSeverity LspCoreLog)
forall a b (m :: * -> *).
(a -> b) -> LogAction m b -> LogAction m a
cmap ((LspCoreLog -> LspProcessingLog)
-> WithSeverity LspCoreLog -> WithSeverity LspProcessingLog
forall a b. (a -> b) -> WithSeverity a -> WithSeverity b
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap LspCoreLog -> LspProcessingLog
LspCore) LogAction m (WithSeverity LspProcessingLog)
logger) (Text -> Value -> Value
lookForConfigSection Text
section (Value -> Value) -> Value -> Value
forall a b. (a -> b) -> a -> b
$ TMessage
@'ClientToServer
@'Notification
'Method_WorkspaceDidChangeConfiguration
TNotificationMessage
@'ClientToServer 'Method_WorkspaceDidChangeConfiguration
req TNotificationMessage
@'ClientToServer 'Method_WorkspaceDidChangeConfiguration
-> Getting
Value
(TNotificationMessage
@'ClientToServer 'Method_WorkspaceDidChangeConfiguration)
Value
-> Value
forall s a. s -> Getting a s a -> a
^. (DidChangeConfigurationParams
-> Const @(*) Value DidChangeConfigurationParams)
-> TNotificationMessage
@'ClientToServer 'Method_WorkspaceDidChangeConfiguration
-> Const
@(*)
Value
(TNotificationMessage
@'ClientToServer 'Method_WorkspaceDidChangeConfiguration)
forall s a. HasParams s a => Lens' s a
Lens'
(TNotificationMessage
@'ClientToServer 'Method_WorkspaceDidChangeConfiguration)
DidChangeConfigurationParams
L.params ((DidChangeConfigurationParams
-> Const @(*) Value DidChangeConfigurationParams)
-> TNotificationMessage
@'ClientToServer 'Method_WorkspaceDidChangeConfiguration
-> Const
@(*)
Value
(TNotificationMessage
@'ClientToServer 'Method_WorkspaceDidChangeConfiguration))
-> ((Value -> Const @(*) Value Value)
-> DidChangeConfigurationParams
-> Const @(*) Value DidChangeConfigurationParams)
-> Getting
Value
(TNotificationMessage
@'ClientToServer 'Method_WorkspaceDidChangeConfiguration)
Value
forall b c a. (b -> c) -> (a -> b) -> a -> c
. (Value -> Const @(*) Value Value)
-> DidChangeConfigurationParams
-> Const @(*) Value DidChangeConfigurationParams
forall s a. HasSettings s a => Lens' s a
Lens' DidChangeConfigurationParams Value
L.settings)
LogAction m (WithSeverity LspCoreLog) -> m ()
forall (m :: * -> *) config.
((m :: (* -> *)) ~ (LspM config :: (* -> *))) =>
LogAction m (WithSeverity LspCoreLog) -> m ()
requestConfigUpdate ((WithSeverity LspCoreLog -> WithSeverity LspProcessingLog)
-> LogAction m (WithSeverity LspProcessingLog)
-> LogAction m (WithSeverity LspCoreLog)
forall a b (m :: * -> *).
(a -> b) -> LogAction m b -> LogAction m a
cmap ((LspCoreLog -> LspProcessingLog)
-> WithSeverity LspCoreLog -> WithSeverity LspProcessingLog
forall a b. (a -> b) -> WithSeverity a -> WithSeverity b
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap LspCoreLog -> LspProcessingLog
LspCore) LogAction m (WithSeverity LspProcessingLog)
logger)
vfsFunc ::
forall m n a config.
(m ~ LspM config, n ~ WriterT [WithSeverity VfsLog] (State VFS)) =>
LogAction m (WithSeverity LspProcessingLog) ->
(LogAction n (WithSeverity VfsLog) -> a -> n ()) ->
a ->
m ()
vfsFunc :: forall (m :: * -> *) (n :: * -> *) a config.
((m :: (* -> *)) ~ (LspM config :: (* -> *)),
(n :: (* -> *))
~ (WriterT [WithSeverity VfsLog] (State VFS) :: (* -> *))) =>
LogAction m (WithSeverity LspProcessingLog)
-> (LogAction n (WithSeverity VfsLog) -> a -> n ()) -> a -> m ()
vfsFunc LogAction m (WithSeverity LspProcessingLog)
logger LogAction n (WithSeverity VfsLog) -> a -> n ()
modifyVfs a
req = do
[WithSeverity VfsLog]
logs <- (LanguageContextState config -> TVar VFSData)
-> (VFSData -> ([WithSeverity VfsLog], VFSData))
-> m [WithSeverity VfsLog]
forall config (m :: * -> *) s a.
MonadLsp config m =>
(LanguageContextState config -> TVar s) -> (s -> (a, s)) -> m a
stateState LanguageContextState config -> TVar VFSData
forall config. LanguageContextState config -> TVar VFSData
resVFS ((VFSData -> ([WithSeverity VfsLog], VFSData))
-> m [WithSeverity VfsLog])
-> (VFSData -> ([WithSeverity VfsLog], VFSData))
-> m [WithSeverity VfsLog]
forall a b. (a -> b) -> a -> b
$ \(VFSData VFS
vfs Map String String
rm) ->
let ([WithSeverity VfsLog]
ls, VFS
vfs') = (State VFS [WithSeverity VfsLog]
-> VFS -> ([WithSeverity VfsLog], VFS))
-> VFS
-> State VFS [WithSeverity VfsLog]
-> ([WithSeverity VfsLog], VFS)
forall a b c. (a -> b -> c) -> b -> a -> c
flip State VFS [WithSeverity VfsLog]
-> VFS -> ([WithSeverity VfsLog], VFS)
forall s a. State s a -> s -> (a, s)
runState VFS
vfs (State VFS [WithSeverity VfsLog] -> ([WithSeverity VfsLog], VFS))
-> State VFS [WithSeverity VfsLog] -> ([WithSeverity VfsLog], VFS)
forall a b. (a -> b) -> a -> b
$ WriterT [WithSeverity VfsLog] (State VFS) ()
-> State VFS [WithSeverity VfsLog]
forall (m :: * -> *) w a. Monad m => WriterT w m a -> m w
execWriterT (WriterT [WithSeverity VfsLog] (State VFS) ()
-> State VFS [WithSeverity VfsLog])
-> WriterT [WithSeverity VfsLog] (State VFS) ()
-> State VFS [WithSeverity VfsLog]
forall a b. (a -> b) -> a -> b
$ LogAction n (WithSeverity VfsLog) -> a -> n ()
modifyVfs LogAction n (WithSeverity VfsLog)
innerLogger a
req
in ([WithSeverity VfsLog]
ls, VFS -> Map String String -> VFSData
VFSData VFS
vfs' Map String String
rm)
(WithSeverity VfsLog -> m ()) -> [WithSeverity VfsLog] -> m ()
forall (t :: * -> *) (f :: * -> *) a b.
(Foldable t, Applicative f) =>
(a -> f b) -> t a -> f ()
traverse_ (\WithSeverity VfsLog
l -> LogAction m (WithSeverity LspProcessingLog)
logger LogAction m (WithSeverity LspProcessingLog)
-> WithSeverity LspProcessingLog -> m ()
forall (m :: * -> *) msg. LogAction m msg -> msg -> m ()
<& (VfsLog -> LspProcessingLog)
-> WithSeverity VfsLog -> WithSeverity LspProcessingLog
forall a b. (a -> b) -> WithSeverity a -> WithSeverity b
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap VfsLog -> LspProcessingLog
VfsLog WithSeverity VfsLog
l) [WithSeverity VfsLog]
logs
where
innerLogger :: LogAction n (WithSeverity VfsLog)
innerLogger :: LogAction n (WithSeverity VfsLog)
innerLogger = (WithSeverity VfsLog -> n ()) -> LogAction n (WithSeverity VfsLog)
forall (m :: * -> *) msg. (msg -> m ()) -> LogAction m msg
LogAction ((WithSeverity VfsLog -> n ())
-> LogAction n (WithSeverity VfsLog))
-> (WithSeverity VfsLog -> n ())
-> LogAction n (WithSeverity VfsLog)
forall a b. (a -> b) -> a -> b
$ \WithSeverity VfsLog
m -> [WithSeverity VfsLog] -> n ()
forall w (m :: * -> *). MonadWriter w m => w -> m ()
tell [WithSeverity VfsLog
m]
updateWorkspaceFolders :: TMessage Method_WorkspaceDidChangeWorkspaceFolders -> LspM config ()
updateWorkspaceFolders :: forall config.
TMessage
@'ClientToServer
@'Notification
'Method_WorkspaceDidChangeWorkspaceFolders
-> LspM config ()
updateWorkspaceFolders (TNotificationMessage Text
_ SClientMethod
@'Notification 'Method_WorkspaceDidChangeWorkspaceFolders
_ MessageParams
@'ClientToServer
@'Notification
'Method_WorkspaceDidChangeWorkspaceFolders
params) = do
let toRemove :: [WorkspaceFolder]
toRemove = DidChangeWorkspaceFoldersParams
MessageParams
@'ClientToServer
@'Notification
'Method_WorkspaceDidChangeWorkspaceFolders
params DidChangeWorkspaceFoldersParams
-> Getting
[WorkspaceFolder] DidChangeWorkspaceFoldersParams [WorkspaceFolder]
-> [WorkspaceFolder]
forall s a. s -> Getting a s a -> a
^. (WorkspaceFoldersChangeEvent
-> Const @(*) [WorkspaceFolder] WorkspaceFoldersChangeEvent)
-> DidChangeWorkspaceFoldersParams
-> Const @(*) [WorkspaceFolder] DidChangeWorkspaceFoldersParams
forall s a. HasEvent s a => Lens' s a
Lens' DidChangeWorkspaceFoldersParams WorkspaceFoldersChangeEvent
L.event ((WorkspaceFoldersChangeEvent
-> Const @(*) [WorkspaceFolder] WorkspaceFoldersChangeEvent)
-> DidChangeWorkspaceFoldersParams
-> Const @(*) [WorkspaceFolder] DidChangeWorkspaceFoldersParams)
-> (([WorkspaceFolder]
-> Const @(*) [WorkspaceFolder] [WorkspaceFolder])
-> WorkspaceFoldersChangeEvent
-> Const @(*) [WorkspaceFolder] WorkspaceFoldersChangeEvent)
-> Getting
[WorkspaceFolder] DidChangeWorkspaceFoldersParams [WorkspaceFolder]
forall b c a. (b -> c) -> (a -> b) -> a -> c
. ([WorkspaceFolder]
-> Const @(*) [WorkspaceFolder] [WorkspaceFolder])
-> WorkspaceFoldersChangeEvent
-> Const @(*) [WorkspaceFolder] WorkspaceFoldersChangeEvent
forall s a. HasRemoved s a => Lens' s a
Lens' WorkspaceFoldersChangeEvent [WorkspaceFolder]
L.removed
toAdd :: [WorkspaceFolder]
toAdd = DidChangeWorkspaceFoldersParams
MessageParams
@'ClientToServer
@'Notification
'Method_WorkspaceDidChangeWorkspaceFolders
params DidChangeWorkspaceFoldersParams
-> Getting
[WorkspaceFolder] DidChangeWorkspaceFoldersParams [WorkspaceFolder]
-> [WorkspaceFolder]
forall s a. s -> Getting a s a -> a
^. (WorkspaceFoldersChangeEvent
-> Const @(*) [WorkspaceFolder] WorkspaceFoldersChangeEvent)
-> DidChangeWorkspaceFoldersParams
-> Const @(*) [WorkspaceFolder] DidChangeWorkspaceFoldersParams
forall s a. HasEvent s a => Lens' s a
Lens' DidChangeWorkspaceFoldersParams WorkspaceFoldersChangeEvent
L.event ((WorkspaceFoldersChangeEvent
-> Const @(*) [WorkspaceFolder] WorkspaceFoldersChangeEvent)
-> DidChangeWorkspaceFoldersParams
-> Const @(*) [WorkspaceFolder] DidChangeWorkspaceFoldersParams)
-> (([WorkspaceFolder]
-> Const @(*) [WorkspaceFolder] [WorkspaceFolder])
-> WorkspaceFoldersChangeEvent
-> Const @(*) [WorkspaceFolder] WorkspaceFoldersChangeEvent)
-> Getting
[WorkspaceFolder] DidChangeWorkspaceFoldersParams [WorkspaceFolder]
forall b c a. (b -> c) -> (a -> b) -> a -> c
. ([WorkspaceFolder]
-> Const @(*) [WorkspaceFolder] [WorkspaceFolder])
-> WorkspaceFoldersChangeEvent
-> Const @(*) [WorkspaceFolder] WorkspaceFoldersChangeEvent
forall s a. HasAdded s a => Lens' s a
Lens' WorkspaceFoldersChangeEvent [WorkspaceFolder]
L.added
newWfs :: [WorkspaceFolder] -> [WorkspaceFolder]
newWfs [WorkspaceFolder]
oldWfs = (WorkspaceFolder -> [WorkspaceFolder] -> [WorkspaceFolder])
-> [WorkspaceFolder] -> [WorkspaceFolder] -> [WorkspaceFolder]
forall a b. (a -> b -> b) -> b -> [a] -> b
forall (t :: * -> *) a b.
Foldable t =>
(a -> b -> b) -> b -> t a -> b
foldr WorkspaceFolder -> [WorkspaceFolder] -> [WorkspaceFolder]
forall a. Eq a => a -> [a] -> [a]
delete [WorkspaceFolder]
oldWfs [WorkspaceFolder]
toRemove [WorkspaceFolder] -> [WorkspaceFolder] -> [WorkspaceFolder]
forall a. Semigroup a => a -> a -> a
<> [WorkspaceFolder]
toAdd
(LanguageContextState config -> TVar [WorkspaceFolder])
-> ([WorkspaceFolder] -> [WorkspaceFolder]) -> LspM config ()
forall config (m :: * -> *) a.
MonadLsp config m =>
(LanguageContextState config -> TVar a) -> (a -> a) -> m ()
modifyState LanguageContextState config -> TVar [WorkspaceFolder]
forall config.
LanguageContextState config -> TVar [WorkspaceFolder]
resWorkspaceFolders [WorkspaceFolder] -> [WorkspaceFolder]
newWfs