{- 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.SemanticTokensParams 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.Internal.Types.ProgressToken
import qualified Language.LSP.Protocol.Internal.Types.TextDocumentIdentifier
import qualified Language.LSP.Protocol.Types.Common

{-|
@since 3.16.0
-}
data SemanticTokensParams = SemanticTokensParams 
  { {-|
  An optional token that a server can use to report work done progress.
  -}
  SemanticTokensParams -> Maybe ProgressToken
_workDoneToken :: (Maybe Language.LSP.Protocol.Internal.Types.ProgressToken.ProgressToken)
  , {-|
  An optional token that a server can use to report partial results (e.g. streaming) to
  the client.
  -}
  SemanticTokensParams -> Maybe ProgressToken
_partialResultToken :: (Maybe Language.LSP.Protocol.Internal.Types.ProgressToken.ProgressToken)
  , {-|
  The text document.
  -}
  SemanticTokensParams -> TextDocumentIdentifier
_textDocument :: Language.LSP.Protocol.Internal.Types.TextDocumentIdentifier.TextDocumentIdentifier
  }
  deriving stock (Int -> SemanticTokensParams -> ShowS
[SemanticTokensParams] -> ShowS
SemanticTokensParams -> String
(Int -> SemanticTokensParams -> ShowS)
-> (SemanticTokensParams -> String)
-> ([SemanticTokensParams] -> ShowS)
-> Show SemanticTokensParams
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> SemanticTokensParams -> ShowS
showsPrec :: Int -> SemanticTokensParams -> ShowS
$cshow :: SemanticTokensParams -> String
show :: SemanticTokensParams -> String
$cshowList :: [SemanticTokensParams] -> ShowS
showList :: [SemanticTokensParams] -> ShowS
Show, SemanticTokensParams -> SemanticTokensParams -> Bool
(SemanticTokensParams -> SemanticTokensParams -> Bool)
-> (SemanticTokensParams -> SemanticTokensParams -> Bool)
-> Eq SemanticTokensParams
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: SemanticTokensParams -> SemanticTokensParams -> Bool
== :: SemanticTokensParams -> SemanticTokensParams -> Bool
$c/= :: SemanticTokensParams -> SemanticTokensParams -> Bool
/= :: SemanticTokensParams -> SemanticTokensParams -> Bool
Eq, Eq SemanticTokensParams
Eq SemanticTokensParams =>
(SemanticTokensParams -> SemanticTokensParams -> Ordering)
-> (SemanticTokensParams -> SemanticTokensParams -> Bool)
-> (SemanticTokensParams -> SemanticTokensParams -> Bool)
-> (SemanticTokensParams -> SemanticTokensParams -> Bool)
-> (SemanticTokensParams -> SemanticTokensParams -> Bool)
-> (SemanticTokensParams
    -> SemanticTokensParams -> SemanticTokensParams)
-> (SemanticTokensParams
    -> SemanticTokensParams -> SemanticTokensParams)
-> Ord SemanticTokensParams
SemanticTokensParams -> SemanticTokensParams -> Bool
SemanticTokensParams -> SemanticTokensParams -> Ordering
SemanticTokensParams
-> SemanticTokensParams -> SemanticTokensParams
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 :: SemanticTokensParams -> SemanticTokensParams -> Ordering
compare :: SemanticTokensParams -> SemanticTokensParams -> Ordering
$c< :: SemanticTokensParams -> SemanticTokensParams -> Bool
< :: SemanticTokensParams -> SemanticTokensParams -> Bool
$c<= :: SemanticTokensParams -> SemanticTokensParams -> Bool
<= :: SemanticTokensParams -> SemanticTokensParams -> Bool
$c> :: SemanticTokensParams -> SemanticTokensParams -> Bool
> :: SemanticTokensParams -> SemanticTokensParams -> Bool
$c>= :: SemanticTokensParams -> SemanticTokensParams -> Bool
>= :: SemanticTokensParams -> SemanticTokensParams -> Bool
$cmax :: SemanticTokensParams
-> SemanticTokensParams -> SemanticTokensParams
max :: SemanticTokensParams
-> SemanticTokensParams -> SemanticTokensParams
$cmin :: SemanticTokensParams
-> SemanticTokensParams -> SemanticTokensParams
min :: SemanticTokensParams
-> SemanticTokensParams -> SemanticTokensParams
Ord, (forall x. SemanticTokensParams -> Rep SemanticTokensParams x)
-> (forall x. Rep SemanticTokensParams x -> SemanticTokensParams)
-> Generic SemanticTokensParams
forall x. Rep SemanticTokensParams x -> SemanticTokensParams
forall x. SemanticTokensParams -> Rep SemanticTokensParams x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cfrom :: forall x. SemanticTokensParams -> Rep SemanticTokensParams x
from :: forall x. SemanticTokensParams -> Rep SemanticTokensParams x
$cto :: forall x. Rep SemanticTokensParams x -> SemanticTokensParams
to :: forall x. Rep SemanticTokensParams x -> SemanticTokensParams
Generic)
  deriving anyclass (SemanticTokensParams -> ()
(SemanticTokensParams -> ()) -> NFData SemanticTokensParams
forall a. (a -> ()) -> NFData a
$crnf :: SemanticTokensParams -> ()
rnf :: SemanticTokensParams -> ()
NFData, Eq SemanticTokensParams
Eq SemanticTokensParams =>
(Int -> SemanticTokensParams -> Int)
-> (SemanticTokensParams -> Int) -> Hashable SemanticTokensParams
Int -> SemanticTokensParams -> Int
SemanticTokensParams -> Int
forall a. Eq a => (Int -> a -> Int) -> (a -> Int) -> Hashable a
$chashWithSalt :: Int -> SemanticTokensParams -> Int
hashWithSalt :: Int -> SemanticTokensParams -> Int
$chash :: SemanticTokensParams -> Int
hash :: SemanticTokensParams -> Int
Hashable)
  deriving (forall ann. SemanticTokensParams -> Doc ann)
-> (forall ann. [SemanticTokensParams] -> Doc ann)
-> Pretty SemanticTokensParams
forall ann. [SemanticTokensParams] -> Doc ann
forall ann. SemanticTokensParams -> Doc ann
forall a.
(forall ann. a -> Doc ann)
-> (forall ann. [a] -> Doc ann) -> Pretty a
$cpretty :: forall ann. SemanticTokensParams -> Doc ann
pretty :: forall ann. SemanticTokensParams -> Doc ann
$cprettyList :: forall ann. [SemanticTokensParams] -> Doc ann
prettyList :: forall ann. [SemanticTokensParams] -> Doc ann
Pretty via (ViaJSON SemanticTokensParams)

instance Aeson.ToJSON SemanticTokensParams where
  toJSON :: SemanticTokensParams -> Value
toJSON (SemanticTokensParams Maybe ProgressToken
arg0 Maybe ProgressToken
arg1 TextDocumentIdentifier
arg2) = [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
"workDoneToken" String -> Maybe ProgressToken -> [Pair]
forall e kv v.
(KeyValue e kv, ToJSON v) =>
String -> Maybe v -> [kv]
Language.LSP.Protocol.Types.Common..=? Maybe ProgressToken
arg0
    ,String
"partialResultToken" String -> Maybe ProgressToken -> [Pair]
forall e kv v.
(KeyValue e kv, ToJSON v) =>
String -> Maybe v -> [kv]
Language.LSP.Protocol.Types.Common..=? Maybe ProgressToken
arg1
    ,[Key
"textDocument" Key -> TextDocumentIdentifier -> Pair
forall v. ToJSON v => Key -> v -> Pair
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
Aeson..= TextDocumentIdentifier
arg2]]

instance Aeson.FromJSON SemanticTokensParams where
  parseJSON :: Value -> Parser SemanticTokensParams
parseJSON = String
-> (Object -> Parser SemanticTokensParams)
-> Value
-> Parser SemanticTokensParams
forall a. String -> (Object -> Parser a) -> Value -> Parser a
Aeson.withObject String
"SemanticTokensParams" ((Object -> Parser SemanticTokensParams)
 -> Value -> Parser SemanticTokensParams)
-> (Object -> Parser SemanticTokensParams)
-> Value
-> Parser SemanticTokensParams
forall a b. (a -> b) -> a -> b
$ \Object
arg -> Maybe ProgressToken
-> Maybe ProgressToken
-> TextDocumentIdentifier
-> SemanticTokensParams
SemanticTokensParams (Maybe ProgressToken
 -> Maybe ProgressToken
 -> TextDocumentIdentifier
 -> SemanticTokensParams)
-> Parser (Maybe ProgressToken)
-> Parser
     (Maybe ProgressToken
      -> TextDocumentIdentifier -> SemanticTokensParams)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Object
arg Object -> Key -> Parser (Maybe ProgressToken)
forall v. FromJSON v => Object -> Key -> Parser (Maybe v)
Language.LSP.Protocol.Types.Common..:!? Key
"workDoneToken" Parser
  (Maybe ProgressToken
   -> TextDocumentIdentifier -> SemanticTokensParams)
-> Parser (Maybe ProgressToken)
-> Parser (TextDocumentIdentifier -> SemanticTokensParams)
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 ProgressToken)
forall v. FromJSON v => Object -> Key -> Parser (Maybe v)
Language.LSP.Protocol.Types.Common..:!? Key
"partialResultToken" Parser (TextDocumentIdentifier -> SemanticTokensParams)
-> Parser TextDocumentIdentifier -> Parser SemanticTokensParams
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 TextDocumentIdentifier
forall a. FromJSON a => Object -> Key -> Parser a
Aeson..: Key
"textDocument"