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