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

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

instance Aeson.ToJSON DefinitionParams where
  toJSON :: DefinitionParams -> Value
toJSON (DefinitionParams TextDocumentIdentifier
arg0 Position
arg1 Maybe ProgressToken
arg2 Maybe ProgressToken
arg3) = [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
"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
arg0]
    ,[Key
"position" Key -> Position -> Pair
forall v. ToJSON v => Key -> v -> Pair
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
Aeson..= Position
arg1]
    ,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
arg2
    ,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
arg3]

instance Aeson.FromJSON DefinitionParams where
  parseJSON :: Value -> Parser DefinitionParams
parseJSON = String
-> (Object -> Parser DefinitionParams)
-> Value
-> Parser DefinitionParams
forall a. String -> (Object -> Parser a) -> Value -> Parser a
Aeson.withObject String
"DefinitionParams" ((Object -> Parser DefinitionParams)
 -> Value -> Parser DefinitionParams)
-> (Object -> Parser DefinitionParams)
-> Value
-> Parser DefinitionParams
forall a b. (a -> b) -> a -> b
$ \Object
arg -> TextDocumentIdentifier
-> Position
-> Maybe ProgressToken
-> Maybe ProgressToken
-> DefinitionParams
DefinitionParams (TextDocumentIdentifier
 -> Position
 -> Maybe ProgressToken
 -> Maybe ProgressToken
 -> DefinitionParams)
-> Parser TextDocumentIdentifier
-> Parser
     (Position
      -> Maybe ProgressToken -> Maybe ProgressToken -> DefinitionParams)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Object
arg Object -> Key -> Parser TextDocumentIdentifier
forall a. FromJSON a => Object -> Key -> Parser a
Aeson..: Key
"textDocument" Parser
  (Position
   -> Maybe ProgressToken -> Maybe ProgressToken -> DefinitionParams)
-> Parser Position
-> Parser
     (Maybe ProgressToken -> Maybe ProgressToken -> DefinitionParams)
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 Position
forall a. FromJSON a => Object -> Key -> Parser a
Aeson..: Key
"position" Parser
  (Maybe ProgressToken -> Maybe ProgressToken -> DefinitionParams)
-> Parser (Maybe ProgressToken)
-> Parser (Maybe ProgressToken -> DefinitionParams)
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
"workDoneToken" Parser (Maybe ProgressToken -> DefinitionParams)
-> Parser (Maybe ProgressToken) -> Parser DefinitionParams
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"