module Patrol.Type.Thread where

import qualified Data.Aeson as Aeson
import qualified Data.Text as Text
import qualified Patrol.Extra.Aeson as Aeson
import qualified Patrol.Type.Stacktrace as Stacktrace

-- | <https://develop.sentry.dev/sdk/event-payloads/types/#thread>
data Thread = Thread
  { Thread -> Maybe Bool
crashed :: Maybe Bool,
    Thread -> Maybe Bool
current :: Maybe Bool,
    Thread -> Text
id :: Text.Text,
    Thread -> Text
name :: Text.Text,
    Thread -> Maybe Stacktrace
stacktrace :: Maybe Stacktrace.Stacktrace
  }
  deriving (Thread -> Thread -> Bool
(Thread -> Thread -> Bool)
-> (Thread -> Thread -> Bool) -> Eq Thread
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: Thread -> Thread -> Bool
== :: Thread -> Thread -> Bool
$c/= :: Thread -> Thread -> Bool
/= :: Thread -> Thread -> Bool
Eq, Int -> Thread -> ShowS
[Thread] -> ShowS
Thread -> String
(Int -> Thread -> ShowS)
-> (Thread -> String) -> ([Thread] -> ShowS) -> Show Thread
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> Thread -> ShowS
showsPrec :: Int -> Thread -> ShowS
$cshow :: Thread -> String
show :: Thread -> String
$cshowList :: [Thread] -> ShowS
showList :: [Thread] -> ShowS
Show)

instance Aeson.ToJSON Thread where
  toJSON :: Thread -> Value
toJSON Thread
thread =
    [Pair] -> Value
Aeson.intoObject
      [ String -> Maybe Bool -> Pair
forall a. ToJSON a => String -> a -> Pair
Aeson.pair String
"crashed" (Maybe Bool -> Pair) -> Maybe Bool -> Pair
forall a b. (a -> b) -> a -> b
$ Thread -> Maybe Bool
crashed Thread
thread,
        String -> Maybe Bool -> Pair
forall a. ToJSON a => String -> a -> Pair
Aeson.pair String
"current" (Maybe Bool -> Pair) -> Maybe Bool -> Pair
forall a b. (a -> b) -> a -> b
$ Thread -> Maybe Bool
current Thread
thread,
        String -> Text -> Pair
forall a. ToJSON a => String -> a -> Pair
Aeson.pair String
"id" (Text -> Pair) -> Text -> Pair
forall a b. (a -> b) -> a -> b
$ Thread -> Text
Patrol.Type.Thread.id Thread
thread,
        String -> Text -> Pair
forall a. ToJSON a => String -> a -> Pair
Aeson.pair String
"name" (Text -> Pair) -> Text -> Pair
forall a b. (a -> b) -> a -> b
$ Thread -> Text
name Thread
thread,
        String -> Maybe Stacktrace -> Pair
forall a. ToJSON a => String -> a -> Pair
Aeson.pair String
"stacktrace" (Maybe Stacktrace -> Pair) -> Maybe Stacktrace -> Pair
forall a b. (a -> b) -> a -> b
$ Thread -> Maybe Stacktrace
stacktrace Thread
thread
      ]

empty :: Thread
empty :: Thread
empty =
  Thread
    { crashed :: Maybe Bool
crashed = Maybe Bool
forall a. Maybe a
Nothing,
      current :: Maybe Bool
current = Maybe Bool
forall a. Maybe a
Nothing,
      id :: Text
Patrol.Type.Thread.id = Text
Text.empty,
      name :: Text
name = Text
Text.empty,
      stacktrace :: Maybe Stacktrace
stacktrace = Maybe Stacktrace
forall a. Maybe a
Nothing
    }