{- ORMOLU_DISABLE -}
{- HLINT ignore -}
-- THIS IS A GENERATED FILE, DO NOT EDIT

{-# OPTIONS_GHC -Wno-unused-imports #-}
{-# OPTIONS_GHC -Wno-unused-matches #-}
{-# OPTIONS_GHC -Wno-deprecations #-}
module Language.LSP.Protocol.Internal.Types.ClientInlayHintResolveOptions 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 Data.Text
import qualified Language.LSP.Protocol.Types.Common

{-|
@since 3.18.0
@proposed
-}
data ClientInlayHintResolveOptions = ClientInlayHintResolveOptions 
  { {-|
  The properties that a client can resolve lazily.
  -}
  ClientInlayHintResolveOptions -> [Text]
_properties :: [Data.Text.Text]
  }
  deriving stock (Int -> ClientInlayHintResolveOptions -> ShowS
[ClientInlayHintResolveOptions] -> ShowS
ClientInlayHintResolveOptions -> String
(Int -> ClientInlayHintResolveOptions -> ShowS)
-> (ClientInlayHintResolveOptions -> String)
-> ([ClientInlayHintResolveOptions] -> ShowS)
-> Show ClientInlayHintResolveOptions
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> ClientInlayHintResolveOptions -> ShowS
showsPrec :: Int -> ClientInlayHintResolveOptions -> ShowS
$cshow :: ClientInlayHintResolveOptions -> String
show :: ClientInlayHintResolveOptions -> String
$cshowList :: [ClientInlayHintResolveOptions] -> ShowS
showList :: [ClientInlayHintResolveOptions] -> ShowS
Show, ClientInlayHintResolveOptions
-> ClientInlayHintResolveOptions -> Bool
(ClientInlayHintResolveOptions
 -> ClientInlayHintResolveOptions -> Bool)
-> (ClientInlayHintResolveOptions
    -> ClientInlayHintResolveOptions -> Bool)
-> Eq ClientInlayHintResolveOptions
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: ClientInlayHintResolveOptions
-> ClientInlayHintResolveOptions -> Bool
== :: ClientInlayHintResolveOptions
-> ClientInlayHintResolveOptions -> Bool
$c/= :: ClientInlayHintResolveOptions
-> ClientInlayHintResolveOptions -> Bool
/= :: ClientInlayHintResolveOptions
-> ClientInlayHintResolveOptions -> Bool
Eq, Eq ClientInlayHintResolveOptions
Eq ClientInlayHintResolveOptions =>
(ClientInlayHintResolveOptions
 -> ClientInlayHintResolveOptions -> Ordering)
-> (ClientInlayHintResolveOptions
    -> ClientInlayHintResolveOptions -> Bool)
-> (ClientInlayHintResolveOptions
    -> ClientInlayHintResolveOptions -> Bool)
-> (ClientInlayHintResolveOptions
    -> ClientInlayHintResolveOptions -> Bool)
-> (ClientInlayHintResolveOptions
    -> ClientInlayHintResolveOptions -> Bool)
-> (ClientInlayHintResolveOptions
    -> ClientInlayHintResolveOptions -> ClientInlayHintResolveOptions)
-> (ClientInlayHintResolveOptions
    -> ClientInlayHintResolveOptions -> ClientInlayHintResolveOptions)
-> Ord ClientInlayHintResolveOptions
ClientInlayHintResolveOptions
-> ClientInlayHintResolveOptions -> Bool
ClientInlayHintResolveOptions
-> ClientInlayHintResolveOptions -> Ordering
ClientInlayHintResolveOptions
-> ClientInlayHintResolveOptions -> ClientInlayHintResolveOptions
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 :: ClientInlayHintResolveOptions
-> ClientInlayHintResolveOptions -> Ordering
compare :: ClientInlayHintResolveOptions
-> ClientInlayHintResolveOptions -> Ordering
$c< :: ClientInlayHintResolveOptions
-> ClientInlayHintResolveOptions -> Bool
< :: ClientInlayHintResolveOptions
-> ClientInlayHintResolveOptions -> Bool
$c<= :: ClientInlayHintResolveOptions
-> ClientInlayHintResolveOptions -> Bool
<= :: ClientInlayHintResolveOptions
-> ClientInlayHintResolveOptions -> Bool
$c> :: ClientInlayHintResolveOptions
-> ClientInlayHintResolveOptions -> Bool
> :: ClientInlayHintResolveOptions
-> ClientInlayHintResolveOptions -> Bool
$c>= :: ClientInlayHintResolveOptions
-> ClientInlayHintResolveOptions -> Bool
>= :: ClientInlayHintResolveOptions
-> ClientInlayHintResolveOptions -> Bool
$cmax :: ClientInlayHintResolveOptions
-> ClientInlayHintResolveOptions -> ClientInlayHintResolveOptions
max :: ClientInlayHintResolveOptions
-> ClientInlayHintResolveOptions -> ClientInlayHintResolveOptions
$cmin :: ClientInlayHintResolveOptions
-> ClientInlayHintResolveOptions -> ClientInlayHintResolveOptions
min :: ClientInlayHintResolveOptions
-> ClientInlayHintResolveOptions -> ClientInlayHintResolveOptions
Ord, (forall x.
 ClientInlayHintResolveOptions
 -> Rep ClientInlayHintResolveOptions x)
-> (forall x.
    Rep ClientInlayHintResolveOptions x
    -> ClientInlayHintResolveOptions)
-> Generic ClientInlayHintResolveOptions
forall x.
Rep ClientInlayHintResolveOptions x
-> ClientInlayHintResolveOptions
forall x.
ClientInlayHintResolveOptions
-> Rep ClientInlayHintResolveOptions x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cfrom :: forall x.
ClientInlayHintResolveOptions
-> Rep ClientInlayHintResolveOptions x
from :: forall x.
ClientInlayHintResolveOptions
-> Rep ClientInlayHintResolveOptions x
$cto :: forall x.
Rep ClientInlayHintResolveOptions x
-> ClientInlayHintResolveOptions
to :: forall x.
Rep ClientInlayHintResolveOptions x
-> ClientInlayHintResolveOptions
Generic)
  deriving anyclass (ClientInlayHintResolveOptions -> ()
(ClientInlayHintResolveOptions -> ())
-> NFData ClientInlayHintResolveOptions
forall a. (a -> ()) -> NFData a
$crnf :: ClientInlayHintResolveOptions -> ()
rnf :: ClientInlayHintResolveOptions -> ()
NFData, Eq ClientInlayHintResolveOptions
Eq ClientInlayHintResolveOptions =>
(Int -> ClientInlayHintResolveOptions -> Int)
-> (ClientInlayHintResolveOptions -> Int)
-> Hashable ClientInlayHintResolveOptions
Int -> ClientInlayHintResolveOptions -> Int
ClientInlayHintResolveOptions -> Int
forall a. Eq a => (Int -> a -> Int) -> (a -> Int) -> Hashable a
$chashWithSalt :: Int -> ClientInlayHintResolveOptions -> Int
hashWithSalt :: Int -> ClientInlayHintResolveOptions -> Int
$chash :: ClientInlayHintResolveOptions -> Int
hash :: ClientInlayHintResolveOptions -> Int
Hashable)
  deriving (forall ann. ClientInlayHintResolveOptions -> Doc ann)
-> (forall ann. [ClientInlayHintResolveOptions] -> Doc ann)
-> Pretty ClientInlayHintResolveOptions
forall ann. [ClientInlayHintResolveOptions] -> Doc ann
forall ann. ClientInlayHintResolveOptions -> Doc ann
forall a.
(forall ann. a -> Doc ann)
-> (forall ann. [a] -> Doc ann) -> Pretty a
$cpretty :: forall ann. ClientInlayHintResolveOptions -> Doc ann
pretty :: forall ann. ClientInlayHintResolveOptions -> Doc ann
$cprettyList :: forall ann. [ClientInlayHintResolveOptions] -> Doc ann
prettyList :: forall ann. [ClientInlayHintResolveOptions] -> Doc ann
Pretty via (ViaJSON ClientInlayHintResolveOptions)

instance Aeson.ToJSON ClientInlayHintResolveOptions where
  toJSON :: ClientInlayHintResolveOptions -> Value
toJSON (ClientInlayHintResolveOptions [Text]
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
$  [[Key
"properties" Key -> [Text] -> Pair
forall v. ToJSON v => Key -> v -> Pair
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
Aeson..= [Text]
arg0]]

instance Aeson.FromJSON ClientInlayHintResolveOptions where
  parseJSON :: Value -> Parser ClientInlayHintResolveOptions
parseJSON = String
-> (Object -> Parser ClientInlayHintResolveOptions)
-> Value
-> Parser ClientInlayHintResolveOptions
forall a. String -> (Object -> Parser a) -> Value -> Parser a
Aeson.withObject String
"ClientInlayHintResolveOptions" ((Object -> Parser ClientInlayHintResolveOptions)
 -> Value -> Parser ClientInlayHintResolveOptions)
-> (Object -> Parser ClientInlayHintResolveOptions)
-> Value
-> Parser ClientInlayHintResolveOptions
forall a b. (a -> b) -> a -> b
$ \Object
arg -> [Text] -> ClientInlayHintResolveOptions
ClientInlayHintResolveOptions ([Text] -> ClientInlayHintResolveOptions)
-> Parser [Text] -> Parser ClientInlayHintResolveOptions
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Object
arg Object -> Key -> Parser [Text]
forall a. FromJSON a => Object -> Key -> Parser a
Aeson..: Key
"properties"