{-# OPTIONS_GHC -Wno-unused-imports #-}
{-# OPTIONS_GHC -Wno-unused-matches #-}
{-# OPTIONS_GHC -Wno-deprecations #-}
module Language.LSP.Protocol.Internal.Types.SemanticTokensWorkspaceClientCapabilities 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 SemanticTokensWorkspaceClientCapabilities = SemanticTokensWorkspaceClientCapabilities
{
SemanticTokensWorkspaceClientCapabilities -> Maybe Bool
_refreshSupport :: (Maybe Bool)
}
deriving stock (Int -> SemanticTokensWorkspaceClientCapabilities -> ShowS
[SemanticTokensWorkspaceClientCapabilities] -> ShowS
SemanticTokensWorkspaceClientCapabilities -> String
(Int -> SemanticTokensWorkspaceClientCapabilities -> ShowS)
-> (SemanticTokensWorkspaceClientCapabilities -> String)
-> ([SemanticTokensWorkspaceClientCapabilities] -> ShowS)
-> Show SemanticTokensWorkspaceClientCapabilities
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> SemanticTokensWorkspaceClientCapabilities -> ShowS
showsPrec :: Int -> SemanticTokensWorkspaceClientCapabilities -> ShowS
$cshow :: SemanticTokensWorkspaceClientCapabilities -> String
show :: SemanticTokensWorkspaceClientCapabilities -> String
$cshowList :: [SemanticTokensWorkspaceClientCapabilities] -> ShowS
showList :: [SemanticTokensWorkspaceClientCapabilities] -> ShowS
Show, SemanticTokensWorkspaceClientCapabilities
-> SemanticTokensWorkspaceClientCapabilities -> Bool
(SemanticTokensWorkspaceClientCapabilities
-> SemanticTokensWorkspaceClientCapabilities -> Bool)
-> (SemanticTokensWorkspaceClientCapabilities
-> SemanticTokensWorkspaceClientCapabilities -> Bool)
-> Eq SemanticTokensWorkspaceClientCapabilities
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: SemanticTokensWorkspaceClientCapabilities
-> SemanticTokensWorkspaceClientCapabilities -> Bool
== :: SemanticTokensWorkspaceClientCapabilities
-> SemanticTokensWorkspaceClientCapabilities -> Bool
$c/= :: SemanticTokensWorkspaceClientCapabilities
-> SemanticTokensWorkspaceClientCapabilities -> Bool
/= :: SemanticTokensWorkspaceClientCapabilities
-> SemanticTokensWorkspaceClientCapabilities -> Bool
Eq, Eq SemanticTokensWorkspaceClientCapabilities
Eq SemanticTokensWorkspaceClientCapabilities =>
(SemanticTokensWorkspaceClientCapabilities
-> SemanticTokensWorkspaceClientCapabilities -> Ordering)
-> (SemanticTokensWorkspaceClientCapabilities
-> SemanticTokensWorkspaceClientCapabilities -> Bool)
-> (SemanticTokensWorkspaceClientCapabilities
-> SemanticTokensWorkspaceClientCapabilities -> Bool)
-> (SemanticTokensWorkspaceClientCapabilities
-> SemanticTokensWorkspaceClientCapabilities -> Bool)
-> (SemanticTokensWorkspaceClientCapabilities
-> SemanticTokensWorkspaceClientCapabilities -> Bool)
-> (SemanticTokensWorkspaceClientCapabilities
-> SemanticTokensWorkspaceClientCapabilities
-> SemanticTokensWorkspaceClientCapabilities)
-> (SemanticTokensWorkspaceClientCapabilities
-> SemanticTokensWorkspaceClientCapabilities
-> SemanticTokensWorkspaceClientCapabilities)
-> Ord SemanticTokensWorkspaceClientCapabilities
SemanticTokensWorkspaceClientCapabilities
-> SemanticTokensWorkspaceClientCapabilities -> Bool
SemanticTokensWorkspaceClientCapabilities
-> SemanticTokensWorkspaceClientCapabilities -> Ordering
SemanticTokensWorkspaceClientCapabilities
-> SemanticTokensWorkspaceClientCapabilities
-> SemanticTokensWorkspaceClientCapabilities
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 :: SemanticTokensWorkspaceClientCapabilities
-> SemanticTokensWorkspaceClientCapabilities -> Ordering
compare :: SemanticTokensWorkspaceClientCapabilities
-> SemanticTokensWorkspaceClientCapabilities -> Ordering
$c< :: SemanticTokensWorkspaceClientCapabilities
-> SemanticTokensWorkspaceClientCapabilities -> Bool
< :: SemanticTokensWorkspaceClientCapabilities
-> SemanticTokensWorkspaceClientCapabilities -> Bool
$c<= :: SemanticTokensWorkspaceClientCapabilities
-> SemanticTokensWorkspaceClientCapabilities -> Bool
<= :: SemanticTokensWorkspaceClientCapabilities
-> SemanticTokensWorkspaceClientCapabilities -> Bool
$c> :: SemanticTokensWorkspaceClientCapabilities
-> SemanticTokensWorkspaceClientCapabilities -> Bool
> :: SemanticTokensWorkspaceClientCapabilities
-> SemanticTokensWorkspaceClientCapabilities -> Bool
$c>= :: SemanticTokensWorkspaceClientCapabilities
-> SemanticTokensWorkspaceClientCapabilities -> Bool
>= :: SemanticTokensWorkspaceClientCapabilities
-> SemanticTokensWorkspaceClientCapabilities -> Bool
$cmax :: SemanticTokensWorkspaceClientCapabilities
-> SemanticTokensWorkspaceClientCapabilities
-> SemanticTokensWorkspaceClientCapabilities
max :: SemanticTokensWorkspaceClientCapabilities
-> SemanticTokensWorkspaceClientCapabilities
-> SemanticTokensWorkspaceClientCapabilities
$cmin :: SemanticTokensWorkspaceClientCapabilities
-> SemanticTokensWorkspaceClientCapabilities
-> SemanticTokensWorkspaceClientCapabilities
min :: SemanticTokensWorkspaceClientCapabilities
-> SemanticTokensWorkspaceClientCapabilities
-> SemanticTokensWorkspaceClientCapabilities
Ord, (forall x.
SemanticTokensWorkspaceClientCapabilities
-> Rep SemanticTokensWorkspaceClientCapabilities x)
-> (forall x.
Rep SemanticTokensWorkspaceClientCapabilities x
-> SemanticTokensWorkspaceClientCapabilities)
-> Generic SemanticTokensWorkspaceClientCapabilities
forall x.
Rep SemanticTokensWorkspaceClientCapabilities x
-> SemanticTokensWorkspaceClientCapabilities
forall x.
SemanticTokensWorkspaceClientCapabilities
-> Rep SemanticTokensWorkspaceClientCapabilities x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cfrom :: forall x.
SemanticTokensWorkspaceClientCapabilities
-> Rep SemanticTokensWorkspaceClientCapabilities x
from :: forall x.
SemanticTokensWorkspaceClientCapabilities
-> Rep SemanticTokensWorkspaceClientCapabilities x
$cto :: forall x.
Rep SemanticTokensWorkspaceClientCapabilities x
-> SemanticTokensWorkspaceClientCapabilities
to :: forall x.
Rep SemanticTokensWorkspaceClientCapabilities x
-> SemanticTokensWorkspaceClientCapabilities
Generic)
deriving anyclass (SemanticTokensWorkspaceClientCapabilities -> ()
(SemanticTokensWorkspaceClientCapabilities -> ())
-> NFData SemanticTokensWorkspaceClientCapabilities
forall a. (a -> ()) -> NFData a
$crnf :: SemanticTokensWorkspaceClientCapabilities -> ()
rnf :: SemanticTokensWorkspaceClientCapabilities -> ()
NFData, Eq SemanticTokensWorkspaceClientCapabilities
Eq SemanticTokensWorkspaceClientCapabilities =>
(Int -> SemanticTokensWorkspaceClientCapabilities -> Int)
-> (SemanticTokensWorkspaceClientCapabilities -> Int)
-> Hashable SemanticTokensWorkspaceClientCapabilities
Int -> SemanticTokensWorkspaceClientCapabilities -> Int
SemanticTokensWorkspaceClientCapabilities -> Int
forall a. Eq a => (Int -> a -> Int) -> (a -> Int) -> Hashable a
$chashWithSalt :: Int -> SemanticTokensWorkspaceClientCapabilities -> Int
hashWithSalt :: Int -> SemanticTokensWorkspaceClientCapabilities -> Int
$chash :: SemanticTokensWorkspaceClientCapabilities -> Int
hash :: SemanticTokensWorkspaceClientCapabilities -> Int
Hashable)
deriving (forall ann. SemanticTokensWorkspaceClientCapabilities -> Doc ann)
-> (forall ann.
[SemanticTokensWorkspaceClientCapabilities] -> Doc ann)
-> Pretty SemanticTokensWorkspaceClientCapabilities
forall ann. [SemanticTokensWorkspaceClientCapabilities] -> Doc ann
forall ann. SemanticTokensWorkspaceClientCapabilities -> Doc ann
forall a.
(forall ann. a -> Doc ann)
-> (forall ann. [a] -> Doc ann) -> Pretty a
$cpretty :: forall ann. SemanticTokensWorkspaceClientCapabilities -> Doc ann
pretty :: forall ann. SemanticTokensWorkspaceClientCapabilities -> Doc ann
$cprettyList :: forall ann. [SemanticTokensWorkspaceClientCapabilities] -> Doc ann
prettyList :: forall ann. [SemanticTokensWorkspaceClientCapabilities] -> Doc ann
Pretty via (ViaJSON SemanticTokensWorkspaceClientCapabilities)
instance Aeson.ToJSON SemanticTokensWorkspaceClientCapabilities where
toJSON :: SemanticTokensWorkspaceClientCapabilities -> Value
toJSON (SemanticTokensWorkspaceClientCapabilities Maybe Bool
arg0) = [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
"refreshSupport" 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]
instance Aeson.FromJSON SemanticTokensWorkspaceClientCapabilities where
parseJSON :: Value -> Parser SemanticTokensWorkspaceClientCapabilities
parseJSON = String
-> (Object -> Parser SemanticTokensWorkspaceClientCapabilities)
-> Value
-> Parser SemanticTokensWorkspaceClientCapabilities
forall a. String -> (Object -> Parser a) -> Value -> Parser a
Aeson.withObject String
"SemanticTokensWorkspaceClientCapabilities" ((Object -> Parser SemanticTokensWorkspaceClientCapabilities)
-> Value -> Parser SemanticTokensWorkspaceClientCapabilities)
-> (Object -> Parser SemanticTokensWorkspaceClientCapabilities)
-> Value
-> Parser SemanticTokensWorkspaceClientCapabilities
forall a b. (a -> b) -> a -> b
$ \Object
arg -> Maybe Bool -> SemanticTokensWorkspaceClientCapabilities
SemanticTokensWorkspaceClientCapabilities (Maybe Bool -> SemanticTokensWorkspaceClientCapabilities)
-> Parser (Maybe Bool)
-> Parser SemanticTokensWorkspaceClientCapabilities
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
"refreshSupport"