{-# OPTIONS_GHC -Wno-unused-imports #-}
{-# OPTIONS_GHC -Wno-unused-matches #-}
{-# OPTIONS_GHC -Wno-deprecations #-}
module Language.LSP.Protocol.Internal.Types.DiagnosticClientCapabilities where
import Control.DeepSeq
import Data.Hashable
import GHC.Generics
import Language.LSP.Protocol.Utils.Misc
import Prettyprinter
import qualified Data.Aeson as Aeson
import qualified Data.Row.Aeson as Aeson
import qualified Data.Row.Hashable as Hashable
import qualified Language.LSP.Protocol.Types.Common
data DiagnosticClientCapabilities = DiagnosticClientCapabilities
{
DiagnosticClientCapabilities -> Maybe Bool
_dynamicRegistration :: (Maybe Bool)
,
DiagnosticClientCapabilities -> Maybe Bool
_relatedDocumentSupport :: (Maybe Bool)
}
deriving stock (Int -> DiagnosticClientCapabilities -> ShowS
[DiagnosticClientCapabilities] -> ShowS
DiagnosticClientCapabilities -> String
(Int -> DiagnosticClientCapabilities -> ShowS)
-> (DiagnosticClientCapabilities -> String)
-> ([DiagnosticClientCapabilities] -> ShowS)
-> Show DiagnosticClientCapabilities
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> DiagnosticClientCapabilities -> ShowS
showsPrec :: Int -> DiagnosticClientCapabilities -> ShowS
$cshow :: DiagnosticClientCapabilities -> String
show :: DiagnosticClientCapabilities -> String
$cshowList :: [DiagnosticClientCapabilities] -> ShowS
showList :: [DiagnosticClientCapabilities] -> ShowS
Show, DiagnosticClientCapabilities
-> DiagnosticClientCapabilities -> Bool
(DiagnosticClientCapabilities
-> DiagnosticClientCapabilities -> Bool)
-> (DiagnosticClientCapabilities
-> DiagnosticClientCapabilities -> Bool)
-> Eq DiagnosticClientCapabilities
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: DiagnosticClientCapabilities
-> DiagnosticClientCapabilities -> Bool
== :: DiagnosticClientCapabilities
-> DiagnosticClientCapabilities -> Bool
$c/= :: DiagnosticClientCapabilities
-> DiagnosticClientCapabilities -> Bool
/= :: DiagnosticClientCapabilities
-> DiagnosticClientCapabilities -> Bool
Eq, Eq DiagnosticClientCapabilities
Eq DiagnosticClientCapabilities =>
(DiagnosticClientCapabilities
-> DiagnosticClientCapabilities -> Ordering)
-> (DiagnosticClientCapabilities
-> DiagnosticClientCapabilities -> Bool)
-> (DiagnosticClientCapabilities
-> DiagnosticClientCapabilities -> Bool)
-> (DiagnosticClientCapabilities
-> DiagnosticClientCapabilities -> Bool)
-> (DiagnosticClientCapabilities
-> DiagnosticClientCapabilities -> Bool)
-> (DiagnosticClientCapabilities
-> DiagnosticClientCapabilities -> DiagnosticClientCapabilities)
-> (DiagnosticClientCapabilities
-> DiagnosticClientCapabilities -> DiagnosticClientCapabilities)
-> Ord DiagnosticClientCapabilities
DiagnosticClientCapabilities
-> DiagnosticClientCapabilities -> Bool
DiagnosticClientCapabilities
-> DiagnosticClientCapabilities -> Ordering
DiagnosticClientCapabilities
-> DiagnosticClientCapabilities -> DiagnosticClientCapabilities
forall a.
Eq a =>
(a -> a -> Ordering)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> a)
-> (a -> a -> a)
-> Ord a
$ccompare :: DiagnosticClientCapabilities
-> DiagnosticClientCapabilities -> Ordering
compare :: DiagnosticClientCapabilities
-> DiagnosticClientCapabilities -> Ordering
$c< :: DiagnosticClientCapabilities
-> DiagnosticClientCapabilities -> Bool
< :: DiagnosticClientCapabilities
-> DiagnosticClientCapabilities -> Bool
$c<= :: DiagnosticClientCapabilities
-> DiagnosticClientCapabilities -> Bool
<= :: DiagnosticClientCapabilities
-> DiagnosticClientCapabilities -> Bool
$c> :: DiagnosticClientCapabilities
-> DiagnosticClientCapabilities -> Bool
> :: DiagnosticClientCapabilities
-> DiagnosticClientCapabilities -> Bool
$c>= :: DiagnosticClientCapabilities
-> DiagnosticClientCapabilities -> Bool
>= :: DiagnosticClientCapabilities
-> DiagnosticClientCapabilities -> Bool
$cmax :: DiagnosticClientCapabilities
-> DiagnosticClientCapabilities -> DiagnosticClientCapabilities
max :: DiagnosticClientCapabilities
-> DiagnosticClientCapabilities -> DiagnosticClientCapabilities
$cmin :: DiagnosticClientCapabilities
-> DiagnosticClientCapabilities -> DiagnosticClientCapabilities
min :: DiagnosticClientCapabilities
-> DiagnosticClientCapabilities -> DiagnosticClientCapabilities
Ord, (forall x.
DiagnosticClientCapabilities -> Rep DiagnosticClientCapabilities x)
-> (forall x.
Rep DiagnosticClientCapabilities x -> DiagnosticClientCapabilities)
-> Generic DiagnosticClientCapabilities
forall x.
Rep DiagnosticClientCapabilities x -> DiagnosticClientCapabilities
forall x.
DiagnosticClientCapabilities -> Rep DiagnosticClientCapabilities x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cfrom :: forall x.
DiagnosticClientCapabilities -> Rep DiagnosticClientCapabilities x
from :: forall x.
DiagnosticClientCapabilities -> Rep DiagnosticClientCapabilities x
$cto :: forall x.
Rep DiagnosticClientCapabilities x -> DiagnosticClientCapabilities
to :: forall x.
Rep DiagnosticClientCapabilities x -> DiagnosticClientCapabilities
Generic)
deriving anyclass (DiagnosticClientCapabilities -> ()
(DiagnosticClientCapabilities -> ())
-> NFData DiagnosticClientCapabilities
forall a. (a -> ()) -> NFData a
$crnf :: DiagnosticClientCapabilities -> ()
rnf :: DiagnosticClientCapabilities -> ()
NFData, Eq DiagnosticClientCapabilities
Eq DiagnosticClientCapabilities =>
(Int -> DiagnosticClientCapabilities -> Int)
-> (DiagnosticClientCapabilities -> Int)
-> Hashable DiagnosticClientCapabilities
Int -> DiagnosticClientCapabilities -> Int
DiagnosticClientCapabilities -> Int
forall a. Eq a => (Int -> a -> Int) -> (a -> Int) -> Hashable a
$chashWithSalt :: Int -> DiagnosticClientCapabilities -> Int
hashWithSalt :: Int -> DiagnosticClientCapabilities -> Int
$chash :: DiagnosticClientCapabilities -> Int
hash :: DiagnosticClientCapabilities -> Int
Hashable)
deriving (forall ann. DiagnosticClientCapabilities -> Doc ann)
-> (forall ann. [DiagnosticClientCapabilities] -> Doc ann)
-> Pretty DiagnosticClientCapabilities
forall ann. [DiagnosticClientCapabilities] -> Doc ann
forall ann. DiagnosticClientCapabilities -> Doc ann
forall a.
(forall ann. a -> Doc ann)
-> (forall ann. [a] -> Doc ann) -> Pretty a
$cpretty :: forall ann. DiagnosticClientCapabilities -> Doc ann
pretty :: forall ann. DiagnosticClientCapabilities -> Doc ann
$cprettyList :: forall ann. [DiagnosticClientCapabilities] -> Doc ann
prettyList :: forall ann. [DiagnosticClientCapabilities] -> Doc ann
Pretty via (ViaJSON DiagnosticClientCapabilities)
instance Aeson.ToJSON DiagnosticClientCapabilities where
toJSON :: DiagnosticClientCapabilities -> Value
toJSON (DiagnosticClientCapabilities Maybe Bool
arg0 Maybe Bool
arg1) = [Pair] -> Value
Aeson.object ([Pair] -> Value) -> [Pair] -> Value
forall a b. (a -> b) -> a -> b
$ [[Pair]] -> [Pair]
forall (t :: * -> *) a. Foldable t => t [a] -> [a]
concat ([[Pair]] -> [Pair]) -> [[Pair]] -> [Pair]
forall a b. (a -> b) -> a -> b
$ [String
"dynamicRegistration" String -> Maybe Bool -> [Pair]
forall e kv v.
(KeyValue e kv, ToJSON v) =>
String -> Maybe v -> [kv]
Language.LSP.Protocol.Types.Common..=? Maybe Bool
arg0
,String
"relatedDocumentSupport" String -> Maybe Bool -> [Pair]
forall e kv v.
(KeyValue e kv, ToJSON v) =>
String -> Maybe v -> [kv]
Language.LSP.Protocol.Types.Common..=? Maybe Bool
arg1]
instance Aeson.FromJSON DiagnosticClientCapabilities where
parseJSON :: Value -> Parser DiagnosticClientCapabilities
parseJSON = String
-> (Object -> Parser DiagnosticClientCapabilities)
-> Value
-> Parser DiagnosticClientCapabilities
forall a. String -> (Object -> Parser a) -> Value -> Parser a
Aeson.withObject String
"DiagnosticClientCapabilities" ((Object -> Parser DiagnosticClientCapabilities)
-> Value -> Parser DiagnosticClientCapabilities)
-> (Object -> Parser DiagnosticClientCapabilities)
-> Value
-> Parser DiagnosticClientCapabilities
forall a b. (a -> b) -> a -> b
$ \Object
arg -> Maybe Bool -> Maybe Bool -> DiagnosticClientCapabilities
DiagnosticClientCapabilities (Maybe Bool -> Maybe Bool -> DiagnosticClientCapabilities)
-> Parser (Maybe Bool)
-> Parser (Maybe Bool -> DiagnosticClientCapabilities)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Object
arg Object -> Key -> Parser (Maybe Bool)
forall v. FromJSON v => Object -> Key -> Parser (Maybe v)
Language.LSP.Protocol.Types.Common..:!? Key
"dynamicRegistration" Parser (Maybe Bool -> DiagnosticClientCapabilities)
-> Parser (Maybe Bool) -> Parser DiagnosticClientCapabilities
forall a b. Parser (a -> b) -> Parser a -> Parser b
forall (f :: * -> *) a b. Applicative f => f (a -> b) -> f a -> f b
<*> Object
arg Object -> Key -> Parser (Maybe Bool)
forall v. FromJSON v => Object -> Key -> Parser (Maybe v)
Language.LSP.Protocol.Types.Common..:!? Key
"relatedDocumentSupport"