{- 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.PrepareRenameParams 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

{-|

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

instance Aeson.ToJSON PrepareRenameParams where
  toJSON :: PrepareRenameParams -> Value
toJSON (PrepareRenameParams TextDocumentIdentifier
arg0 Position
arg1 Maybe ProgressToken
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
$  [[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]

instance Aeson.FromJSON PrepareRenameParams where
  parseJSON :: Value -> Parser PrepareRenameParams
parseJSON = String
-> (Object -> Parser PrepareRenameParams)
-> Value
-> Parser PrepareRenameParams
forall a. String -> (Object -> Parser a) -> Value -> Parser a
Aeson.withObject String
"PrepareRenameParams" ((Object -> Parser PrepareRenameParams)
 -> Value -> Parser PrepareRenameParams)
-> (Object -> Parser PrepareRenameParams)
-> Value
-> Parser PrepareRenameParams
forall a b. (a -> b) -> a -> b
$ \Object
arg -> TextDocumentIdentifier
-> Position -> Maybe ProgressToken -> PrepareRenameParams
PrepareRenameParams (TextDocumentIdentifier
 -> Position -> Maybe ProgressToken -> PrepareRenameParams)
-> Parser TextDocumentIdentifier
-> Parser (Position -> Maybe ProgressToken -> PrepareRenameParams)
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 -> PrepareRenameParams)
-> Parser Position
-> Parser (Maybe ProgressToken -> PrepareRenameParams)
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 -> PrepareRenameParams)
-> Parser (Maybe ProgressToken) -> Parser PrepareRenameParams
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"