{- 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.RenameFile 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.ChangeAnnotationIdentifier
import qualified Language.LSP.Protocol.Internal.Types.RenameFileOptions
import qualified Language.LSP.Protocol.Types.Common
import qualified Language.LSP.Protocol.Types.Singletons
import qualified Language.LSP.Protocol.Types.Uri

{-|
Rename file operation
-}
data RenameFile = RenameFile 
  { {-|
  An optional annotation identifier describing the operation.

  @since 3.16.0
  -}
  RenameFile -> Maybe ChangeAnnotationIdentifier
_annotationId :: (Maybe Language.LSP.Protocol.Internal.Types.ChangeAnnotationIdentifier.ChangeAnnotationIdentifier)
  , {-|
  A rename
  -}
  RenameFile -> AString "rename"
_kind :: (Language.LSP.Protocol.Types.Singletons.AString "rename")
  , {-|
  The old (existing) location.
  -}
  RenameFile -> Uri
_oldUri :: Language.LSP.Protocol.Types.Uri.Uri
  , {-|
  The new location.
  -}
  RenameFile -> Uri
_newUri :: Language.LSP.Protocol.Types.Uri.Uri
  , {-|
  Rename options.
  -}
  RenameFile -> Maybe RenameFileOptions
_options :: (Maybe Language.LSP.Protocol.Internal.Types.RenameFileOptions.RenameFileOptions)
  }
  deriving stock (Int -> RenameFile -> ShowS
[RenameFile] -> ShowS
RenameFile -> String
(Int -> RenameFile -> ShowS)
-> (RenameFile -> String)
-> ([RenameFile] -> ShowS)
-> Show RenameFile
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> RenameFile -> ShowS
showsPrec :: Int -> RenameFile -> ShowS
$cshow :: RenameFile -> String
show :: RenameFile -> String
$cshowList :: [RenameFile] -> ShowS
showList :: [RenameFile] -> ShowS
Show, RenameFile -> RenameFile -> Bool
(RenameFile -> RenameFile -> Bool)
-> (RenameFile -> RenameFile -> Bool) -> Eq RenameFile
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: RenameFile -> RenameFile -> Bool
== :: RenameFile -> RenameFile -> Bool
$c/= :: RenameFile -> RenameFile -> Bool
/= :: RenameFile -> RenameFile -> Bool
Eq, Eq RenameFile
Eq RenameFile =>
(RenameFile -> RenameFile -> Ordering)
-> (RenameFile -> RenameFile -> Bool)
-> (RenameFile -> RenameFile -> Bool)
-> (RenameFile -> RenameFile -> Bool)
-> (RenameFile -> RenameFile -> Bool)
-> (RenameFile -> RenameFile -> RenameFile)
-> (RenameFile -> RenameFile -> RenameFile)
-> Ord RenameFile
RenameFile -> RenameFile -> Bool
RenameFile -> RenameFile -> Ordering
RenameFile -> RenameFile -> RenameFile
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 :: RenameFile -> RenameFile -> Ordering
compare :: RenameFile -> RenameFile -> Ordering
$c< :: RenameFile -> RenameFile -> Bool
< :: RenameFile -> RenameFile -> Bool
$c<= :: RenameFile -> RenameFile -> Bool
<= :: RenameFile -> RenameFile -> Bool
$c> :: RenameFile -> RenameFile -> Bool
> :: RenameFile -> RenameFile -> Bool
$c>= :: RenameFile -> RenameFile -> Bool
>= :: RenameFile -> RenameFile -> Bool
$cmax :: RenameFile -> RenameFile -> RenameFile
max :: RenameFile -> RenameFile -> RenameFile
$cmin :: RenameFile -> RenameFile -> RenameFile
min :: RenameFile -> RenameFile -> RenameFile
Ord, (forall x. RenameFile -> Rep RenameFile x)
-> (forall x. Rep RenameFile x -> RenameFile) -> Generic RenameFile
forall x. Rep RenameFile x -> RenameFile
forall x. RenameFile -> Rep RenameFile x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cfrom :: forall x. RenameFile -> Rep RenameFile x
from :: forall x. RenameFile -> Rep RenameFile x
$cto :: forall x. Rep RenameFile x -> RenameFile
to :: forall x. Rep RenameFile x -> RenameFile
Generic)
  deriving anyclass (RenameFile -> ()
(RenameFile -> ()) -> NFData RenameFile
forall a. (a -> ()) -> NFData a
$crnf :: RenameFile -> ()
rnf :: RenameFile -> ()
NFData, Eq RenameFile
Eq RenameFile =>
(Int -> RenameFile -> Int)
-> (RenameFile -> Int) -> Hashable RenameFile
Int -> RenameFile -> Int
RenameFile -> Int
forall a. Eq a => (Int -> a -> Int) -> (a -> Int) -> Hashable a
$chashWithSalt :: Int -> RenameFile -> Int
hashWithSalt :: Int -> RenameFile -> Int
$chash :: RenameFile -> Int
hash :: RenameFile -> Int
Hashable)
  deriving (forall ann. RenameFile -> Doc ann)
-> (forall ann. [RenameFile] -> Doc ann) -> Pretty RenameFile
forall ann. [RenameFile] -> Doc ann
forall ann. RenameFile -> Doc ann
forall a.
(forall ann. a -> Doc ann)
-> (forall ann. [a] -> Doc ann) -> Pretty a
$cpretty :: forall ann. RenameFile -> Doc ann
pretty :: forall ann. RenameFile -> Doc ann
$cprettyList :: forall ann. [RenameFile] -> Doc ann
prettyList :: forall ann. [RenameFile] -> Doc ann
Pretty via (ViaJSON RenameFile)

instance Aeson.ToJSON RenameFile where
  toJSON :: RenameFile -> Value
toJSON (RenameFile Maybe ChangeAnnotationIdentifier
arg0 AString "rename"
arg1 Uri
arg2 Uri
arg3 Maybe RenameFileOptions
arg4) = [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
"annotationId" String -> Maybe ChangeAnnotationIdentifier -> [Pair]
forall e kv v.
(KeyValue e kv, ToJSON v) =>
String -> Maybe v -> [kv]
Language.LSP.Protocol.Types.Common..=? Maybe ChangeAnnotationIdentifier
arg0
    ,[Key
"kind" Key -> AString "rename" -> Pair
forall v. ToJSON v => Key -> v -> Pair
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
Aeson..= AString "rename"
arg1]
    ,[Key
"oldUri" Key -> Uri -> Pair
forall v. ToJSON v => Key -> v -> Pair
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
Aeson..= Uri
arg2]
    ,[Key
"newUri" Key -> Uri -> Pair
forall v. ToJSON v => Key -> v -> Pair
forall e kv v. (KeyValue e kv, ToJSON v) => Key -> v -> kv
Aeson..= Uri
arg3]
    ,String
"options" String -> Maybe RenameFileOptions -> [Pair]
forall e kv v.
(KeyValue e kv, ToJSON v) =>
String -> Maybe v -> [kv]
Language.LSP.Protocol.Types.Common..=? Maybe RenameFileOptions
arg4]

instance Aeson.FromJSON RenameFile where
  parseJSON :: Value -> Parser RenameFile
parseJSON = String
-> (Object -> Parser RenameFile) -> Value -> Parser RenameFile
forall a. String -> (Object -> Parser a) -> Value -> Parser a
Aeson.withObject String
"RenameFile" ((Object -> Parser RenameFile) -> Value -> Parser RenameFile)
-> (Object -> Parser RenameFile) -> Value -> Parser RenameFile
forall a b. (a -> b) -> a -> b
$ \Object
arg -> Maybe ChangeAnnotationIdentifier
-> AString "rename"
-> Uri
-> Uri
-> Maybe RenameFileOptions
-> RenameFile
RenameFile (Maybe ChangeAnnotationIdentifier
 -> AString "rename"
 -> Uri
 -> Uri
 -> Maybe RenameFileOptions
 -> RenameFile)
-> Parser (Maybe ChangeAnnotationIdentifier)
-> Parser
     (AString "rename"
      -> Uri -> Uri -> Maybe RenameFileOptions -> RenameFile)
forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$> Object
arg Object -> Key -> Parser (Maybe ChangeAnnotationIdentifier)
forall v. FromJSON v => Object -> Key -> Parser (Maybe v)
Language.LSP.Protocol.Types.Common..:!? Key
"annotationId" Parser
  (AString "rename"
   -> Uri -> Uri -> Maybe RenameFileOptions -> RenameFile)
-> Parser (AString "rename")
-> Parser (Uri -> Uri -> Maybe RenameFileOptions -> RenameFile)
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 (AString "rename")
forall a. FromJSON a => Object -> Key -> Parser a
Aeson..: Key
"kind" Parser (Uri -> Uri -> Maybe RenameFileOptions -> RenameFile)
-> Parser Uri
-> Parser (Uri -> Maybe RenameFileOptions -> RenameFile)
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 Uri
forall a. FromJSON a => Object -> Key -> Parser a
Aeson..: Key
"oldUri" Parser (Uri -> Maybe RenameFileOptions -> RenameFile)
-> Parser Uri -> Parser (Maybe RenameFileOptions -> RenameFile)
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 Uri
forall a. FromJSON a => Object -> Key -> Parser a
Aeson..: Key
"newUri" Parser (Maybe RenameFileOptions -> RenameFile)
-> Parser (Maybe RenameFileOptions) -> Parser RenameFile
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 RenameFileOptions)
forall v. FromJSON v => Object -> Key -> Parser (Maybe v)
Language.LSP.Protocol.Types.Common..:!? Key
"options"