{- 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.Color 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.Types.Common {-| Represents a color in RGBA space. -} data Color = Color { {-| The red component of this color in the range [0-1]. -} _red :: Float , {-| The green component of this color in the range [0-1]. -} _green :: Float , {-| The blue component of this color in the range [0-1]. -} _blue :: Float , {-| The alpha component of this color in the range [0-1]. -} _alpha :: Float } deriving stock (Show, Eq, Ord, Generic) deriving anyclass (NFData, Hashable) deriving Pretty via (ViaJSON Color) instance Aeson.ToJSON Color where toJSON (Color arg0 arg1 arg2 arg3) = Aeson.object $ concat $ [["red" Aeson..= arg0] ,["green" Aeson..= arg1] ,["blue" Aeson..= arg2] ,["alpha" Aeson..= arg3]] instance Aeson.FromJSON Color where parseJSON = Aeson.withObject "Color" $ \arg -> Color <$> arg Aeson..: "red" <*> arg Aeson..: "green" <*> arg Aeson..: "blue" <*> arg Aeson..: "alpha"