-- | Copyright  : Will Thompson and Iñaki García Etxebarria
-- License    : LGPL-2.1
-- Maintainer : Iñaki García Etxebarria

#if (MIN_VERSION_haskell_gi_overloading(1,0,0) && !defined(__HADDOCK_VERSION__))
#define ENABLE_OVERLOADING
#endif

module GI.JavaScriptCore.Enums
    ( 

 -- * Enumerations


-- ** CheckSyntaxMode #enum:CheckSyntaxMode#

    CheckSyntaxMode(..)                     ,


-- ** CheckSyntaxResult #enum:CheckSyntaxResult#

    CheckSyntaxResult(..)                   ,


-- ** OptionType #enum:OptionType#

    OptionType(..)                          ,


-- ** TypedArrayType #enum:TypedArrayType#

    TypedArrayType(..)                      ,




    ) where

import Data.GI.Base.ShortPrelude
import qualified Data.GI.Base.ShortPrelude as SP
import qualified Data.GI.Base.Overloading as O
import qualified Prelude as P

import qualified Data.GI.Base.Attributes as GI.Attributes
import qualified Data.GI.Base.BasicTypes as B.Types
import qualified Data.GI.Base.ManagedPtr as B.ManagedPtr
import qualified Data.GI.Base.GArray as B.GArray
import qualified Data.GI.Base.GClosure as B.GClosure
import qualified Data.GI.Base.GError as B.GError
import qualified Data.GI.Base.GHashTable as B.GHT
import qualified Data.GI.Base.GVariant as B.GVariant
import qualified Data.GI.Base.GValue as B.GValue
import qualified Data.GI.Base.GParamSpec as B.GParamSpec
import qualified Data.GI.Base.CallStack as B.CallStack
import qualified Data.GI.Base.Properties as B.Properties
import qualified Data.GI.Base.Signals as B.Signals
import qualified Control.Monad.IO.Class as MIO
import qualified Data.Coerce as Coerce
import qualified Data.Text as T
import qualified Data.Kind as DK
import qualified Data.ByteString.Char8 as B
import qualified Data.Map as Map
import qualified Foreign.Ptr as FP
import qualified GHC.OverloadedLabels as OL
import qualified GHC.Records as R


-- Enum TypedArrayType
-- | Possible types of the elements contained in a typed array.
-- 
-- /Since: 2.38/
data TypedArrayType = 
      TypedArrayTypeNone
    -- ^ Not a typed array, or type unsupported.
    | TypedArrayTypeInt8
    -- ^ Array elements are 8-bit signed integers (int8_t).
    | TypedArrayTypeInt16
    -- ^ Array elements are 16-bit signed integers (int16_t).
    | TypedArrayTypeInt32
    -- ^ Array elements are 32-bit signed integers (int32_t).
    | TypedArrayTypeInt64
    -- ^ Array elements are 64-bit signed integers (int64_t).
    | TypedArrayTypeUint8
    -- ^ Array elements are 8-bit unsigned integers (uint8_t).
    | TypedArrayTypeUint8Clamped
    -- ^ Array elements are 8-bit unsigned integers (uint8_t).
    | TypedArrayTypeUint16
    -- ^ Array elements are 16-bit unsigned integers (uint16_t).
    | TypedArrayTypeUint32
    -- ^ Array elements are 32-bit unsigned integers (uint32_t).
    | TypedArrayTypeUint64
    -- ^ Array elements are 64-bit unsigned integers (uint64_t).
    | TypedArrayTypeFloat32
    -- ^ Array elements are 32-bit floating point numbers (float).
    | TypedArrayTypeFloat64
    -- ^ Array elements are 64-bit floating point numbers (double).
    | AnotherTypedArrayType Int
    -- ^ Catch-all for unknown values
    deriving (Int -> TypedArrayType -> ShowS
[TypedArrayType] -> ShowS
TypedArrayType -> String
(Int -> TypedArrayType -> ShowS)
-> (TypedArrayType -> String)
-> ([TypedArrayType] -> ShowS)
-> Show TypedArrayType
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> TypedArrayType -> ShowS
showsPrec :: Int -> TypedArrayType -> ShowS
$cshow :: TypedArrayType -> String
show :: TypedArrayType -> String
$cshowList :: [TypedArrayType] -> ShowS
showList :: [TypedArrayType] -> ShowS
Show, TypedArrayType -> TypedArrayType -> Bool
(TypedArrayType -> TypedArrayType -> Bool)
-> (TypedArrayType -> TypedArrayType -> Bool) -> Eq TypedArrayType
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: TypedArrayType -> TypedArrayType -> Bool
== :: TypedArrayType -> TypedArrayType -> Bool
$c/= :: TypedArrayType -> TypedArrayType -> Bool
/= :: TypedArrayType -> TypedArrayType -> Bool
Eq)

instance P.Enum TypedArrayType where
    fromEnum :: TypedArrayType -> Int
fromEnum TypedArrayType
TypedArrayTypeNone = Int
0
    fromEnum TypedArrayType
TypedArrayTypeInt8 = Int
1
    fromEnum TypedArrayType
TypedArrayTypeInt16 = Int
2
    fromEnum TypedArrayType
TypedArrayTypeInt32 = Int
3
    fromEnum TypedArrayType
TypedArrayTypeInt64 = Int
4
    fromEnum TypedArrayType
TypedArrayTypeUint8 = Int
5
    fromEnum TypedArrayType
TypedArrayTypeUint8Clamped = Int
6
    fromEnum TypedArrayType
TypedArrayTypeUint16 = Int
7
    fromEnum TypedArrayType
TypedArrayTypeUint32 = Int
8
    fromEnum TypedArrayType
TypedArrayTypeUint64 = Int
9
    fromEnum TypedArrayType
TypedArrayTypeFloat32 = Int
10
    fromEnum TypedArrayType
TypedArrayTypeFloat64 = Int
11
    fromEnum (AnotherTypedArrayType Int
k) = Int
k

    toEnum :: Int -> TypedArrayType
toEnum Int
0 = TypedArrayType
TypedArrayTypeNone
    toEnum Int
1 = TypedArrayType
TypedArrayTypeInt8
    toEnum Int
2 = TypedArrayType
TypedArrayTypeInt16
    toEnum Int
3 = TypedArrayType
TypedArrayTypeInt32
    toEnum Int
4 = TypedArrayType
TypedArrayTypeInt64
    toEnum Int
5 = TypedArrayType
TypedArrayTypeUint8
    toEnum Int
6 = TypedArrayType
TypedArrayTypeUint8Clamped
    toEnum Int
7 = TypedArrayType
TypedArrayTypeUint16
    toEnum Int
8 = TypedArrayType
TypedArrayTypeUint32
    toEnum Int
9 = TypedArrayType
TypedArrayTypeUint64
    toEnum Int
10 = TypedArrayType
TypedArrayTypeFloat32
    toEnum Int
11 = TypedArrayType
TypedArrayTypeFloat64
    toEnum Int
k = Int -> TypedArrayType
AnotherTypedArrayType Int
k

instance P.Ord TypedArrayType where
    compare :: TypedArrayType -> TypedArrayType -> Ordering
compare TypedArrayType
a TypedArrayType
b = Int -> Int -> Ordering
forall a. Ord a => a -> a -> Ordering
P.compare (TypedArrayType -> Int
forall a. Enum a => a -> Int
P.fromEnum TypedArrayType
a) (TypedArrayType -> Int
forall a. Enum a => a -> Int
P.fromEnum TypedArrayType
b)

-- Enum OptionType
-- | Enum values for options types.
-- 
-- /Since: 2.24/
data OptionType = 
      OptionTypeBoolean
    -- ^ A t'P.Bool' option type.
    | OptionTypeInt
    -- ^ A @/gint/@ option type.
    | OptionTypeUint
    -- ^ A @/guint/@ option type.
    | OptionTypeSize
    -- ^ A @/gsize/@ options type.
    | OptionTypeDouble
    -- ^ A @/gdouble/@ options type.
    | OptionTypeString
    -- ^ A string option type.
    | OptionTypeRangeString
    -- ^ A range string option type.
    | AnotherOptionType Int
    -- ^ Catch-all for unknown values
    deriving (Int -> OptionType -> ShowS
[OptionType] -> ShowS
OptionType -> String
(Int -> OptionType -> ShowS)
-> (OptionType -> String)
-> ([OptionType] -> ShowS)
-> Show OptionType
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> OptionType -> ShowS
showsPrec :: Int -> OptionType -> ShowS
$cshow :: OptionType -> String
show :: OptionType -> String
$cshowList :: [OptionType] -> ShowS
showList :: [OptionType] -> ShowS
Show, OptionType -> OptionType -> Bool
(OptionType -> OptionType -> Bool)
-> (OptionType -> OptionType -> Bool) -> Eq OptionType
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: OptionType -> OptionType -> Bool
== :: OptionType -> OptionType -> Bool
$c/= :: OptionType -> OptionType -> Bool
/= :: OptionType -> OptionType -> Bool
Eq)

instance P.Enum OptionType where
    fromEnum :: OptionType -> Int
fromEnum OptionType
OptionTypeBoolean = Int
0
    fromEnum OptionType
OptionTypeInt = Int
1
    fromEnum OptionType
OptionTypeUint = Int
2
    fromEnum OptionType
OptionTypeSize = Int
3
    fromEnum OptionType
OptionTypeDouble = Int
4
    fromEnum OptionType
OptionTypeString = Int
5
    fromEnum OptionType
OptionTypeRangeString = Int
6
    fromEnum (AnotherOptionType Int
k) = Int
k

    toEnum :: Int -> OptionType
toEnum Int
0 = OptionType
OptionTypeBoolean
    toEnum Int
1 = OptionType
OptionTypeInt
    toEnum Int
2 = OptionType
OptionTypeUint
    toEnum Int
3 = OptionType
OptionTypeSize
    toEnum Int
4 = OptionType
OptionTypeDouble
    toEnum Int
5 = OptionType
OptionTypeString
    toEnum Int
6 = OptionType
OptionTypeRangeString
    toEnum Int
k = Int -> OptionType
AnotherOptionType Int
k

instance P.Ord OptionType where
    compare :: OptionType -> OptionType -> Ordering
compare OptionType
a OptionType
b = Int -> Int -> Ordering
forall a. Ord a => a -> a -> Ordering
P.compare (OptionType -> Int
forall a. Enum a => a -> Int
P.fromEnum OptionType
a) (OptionType -> Int
forall a. Enum a => a -> Int
P.fromEnum OptionType
b)

-- Enum CheckSyntaxResult
-- | Enum values to specify the result of 'GI.JavaScriptCore.Objects.Context.contextCheckSyntax'.
data CheckSyntaxResult = 
      CheckSyntaxResultSuccess
    -- ^ no errors
    | CheckSyntaxResultRecoverableError
    -- ^ recoverable syntax error
    | CheckSyntaxResultIrrecoverableError
    -- ^ irrecoverable syntax error
    | CheckSyntaxResultUnterminatedLiteralError
    -- ^ unterminated literal error
    | CheckSyntaxResultOutOfMemoryError
    -- ^ out of memory error
    | CheckSyntaxResultStackOverflowError
    -- ^ stack overflow error
    | AnotherCheckSyntaxResult Int
    -- ^ Catch-all for unknown values
    deriving (Int -> CheckSyntaxResult -> ShowS
[CheckSyntaxResult] -> ShowS
CheckSyntaxResult -> String
(Int -> CheckSyntaxResult -> ShowS)
-> (CheckSyntaxResult -> String)
-> ([CheckSyntaxResult] -> ShowS)
-> Show CheckSyntaxResult
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> CheckSyntaxResult -> ShowS
showsPrec :: Int -> CheckSyntaxResult -> ShowS
$cshow :: CheckSyntaxResult -> String
show :: CheckSyntaxResult -> String
$cshowList :: [CheckSyntaxResult] -> ShowS
showList :: [CheckSyntaxResult] -> ShowS
Show, CheckSyntaxResult -> CheckSyntaxResult -> Bool
(CheckSyntaxResult -> CheckSyntaxResult -> Bool)
-> (CheckSyntaxResult -> CheckSyntaxResult -> Bool)
-> Eq CheckSyntaxResult
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: CheckSyntaxResult -> CheckSyntaxResult -> Bool
== :: CheckSyntaxResult -> CheckSyntaxResult -> Bool
$c/= :: CheckSyntaxResult -> CheckSyntaxResult -> Bool
/= :: CheckSyntaxResult -> CheckSyntaxResult -> Bool
Eq)

instance P.Enum CheckSyntaxResult where
    fromEnum :: CheckSyntaxResult -> Int
fromEnum CheckSyntaxResult
CheckSyntaxResultSuccess = Int
0
    fromEnum CheckSyntaxResult
CheckSyntaxResultRecoverableError = Int
1
    fromEnum CheckSyntaxResult
CheckSyntaxResultIrrecoverableError = Int
2
    fromEnum CheckSyntaxResult
CheckSyntaxResultUnterminatedLiteralError = Int
3
    fromEnum CheckSyntaxResult
CheckSyntaxResultOutOfMemoryError = Int
4
    fromEnum CheckSyntaxResult
CheckSyntaxResultStackOverflowError = Int
5
    fromEnum (AnotherCheckSyntaxResult Int
k) = Int
k

    toEnum :: Int -> CheckSyntaxResult
toEnum Int
0 = CheckSyntaxResult
CheckSyntaxResultSuccess
    toEnum Int
1 = CheckSyntaxResult
CheckSyntaxResultRecoverableError
    toEnum Int
2 = CheckSyntaxResult
CheckSyntaxResultIrrecoverableError
    toEnum Int
3 = CheckSyntaxResult
CheckSyntaxResultUnterminatedLiteralError
    toEnum Int
4 = CheckSyntaxResult
CheckSyntaxResultOutOfMemoryError
    toEnum Int
5 = CheckSyntaxResult
CheckSyntaxResultStackOverflowError
    toEnum Int
k = Int -> CheckSyntaxResult
AnotherCheckSyntaxResult Int
k

instance P.Ord CheckSyntaxResult where
    compare :: CheckSyntaxResult -> CheckSyntaxResult -> Ordering
compare CheckSyntaxResult
a CheckSyntaxResult
b = Int -> Int -> Ordering
forall a. Ord a => a -> a -> Ordering
P.compare (CheckSyntaxResult -> Int
forall a. Enum a => a -> Int
P.fromEnum CheckSyntaxResult
a) (CheckSyntaxResult -> Int
forall a. Enum a => a -> Int
P.fromEnum CheckSyntaxResult
b)

-- Enum CheckSyntaxMode
-- | Enum values to specify a mode to check for syntax errors in 'GI.JavaScriptCore.Objects.Context.contextCheckSyntax'.
data CheckSyntaxMode = 
      CheckSyntaxModeScript
    -- ^ mode to check syntax of a script
    | CheckSyntaxModeModule
    -- ^ mode to check syntax of a module
    | AnotherCheckSyntaxMode Int
    -- ^ Catch-all for unknown values
    deriving (Int -> CheckSyntaxMode -> ShowS
[CheckSyntaxMode] -> ShowS
CheckSyntaxMode -> String
(Int -> CheckSyntaxMode -> ShowS)
-> (CheckSyntaxMode -> String)
-> ([CheckSyntaxMode] -> ShowS)
-> Show CheckSyntaxMode
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> CheckSyntaxMode -> ShowS
showsPrec :: Int -> CheckSyntaxMode -> ShowS
$cshow :: CheckSyntaxMode -> String
show :: CheckSyntaxMode -> String
$cshowList :: [CheckSyntaxMode] -> ShowS
showList :: [CheckSyntaxMode] -> ShowS
Show, CheckSyntaxMode -> CheckSyntaxMode -> Bool
(CheckSyntaxMode -> CheckSyntaxMode -> Bool)
-> (CheckSyntaxMode -> CheckSyntaxMode -> Bool)
-> Eq CheckSyntaxMode
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: CheckSyntaxMode -> CheckSyntaxMode -> Bool
== :: CheckSyntaxMode -> CheckSyntaxMode -> Bool
$c/= :: CheckSyntaxMode -> CheckSyntaxMode -> Bool
/= :: CheckSyntaxMode -> CheckSyntaxMode -> Bool
Eq)

instance P.Enum CheckSyntaxMode where
    fromEnum :: CheckSyntaxMode -> Int
fromEnum CheckSyntaxMode
CheckSyntaxModeScript = Int
0
    fromEnum CheckSyntaxMode
CheckSyntaxModeModule = Int
1
    fromEnum (AnotherCheckSyntaxMode Int
k) = Int
k

    toEnum :: Int -> CheckSyntaxMode
toEnum Int
0 = CheckSyntaxMode
CheckSyntaxModeScript
    toEnum Int
1 = CheckSyntaxMode
CheckSyntaxModeModule
    toEnum Int
k = Int -> CheckSyntaxMode
AnotherCheckSyntaxMode Int
k

instance P.Ord CheckSyntaxMode where
    compare :: CheckSyntaxMode -> CheckSyntaxMode -> Ordering
compare CheckSyntaxMode
a CheckSyntaxMode
b = Int -> Int -> Ordering
forall a. Ord a => a -> a -> Ordering
P.compare (CheckSyntaxMode -> Int
forall a. Enum a => a -> Int
P.fromEnum CheckSyntaxMode
a) (CheckSyntaxMode -> Int
forall a. Enum a => a -> Int
P.fromEnum CheckSyntaxMode
b)