{-# LANGUAGE DeriveGeneric #-}
module Distribution.Client.Types.BuildResults
( BuildOutcome
, BuildOutcomes
, BuildFailure (..)
, BuildResult (..)
, TestsResult (..)
, DocsResult (..)
) where
import Distribution.Client.Compat.Prelude
import Prelude ()
import Distribution.Types.InstalledPackageInfo (InstalledPackageInfo)
import Distribution.Types.PackageId (PackageId)
import Distribution.Types.UnitId (UnitId)
type BuildOutcome = Either BuildFailure BuildResult
type BuildOutcomes = Map UnitId BuildOutcome
data BuildFailure
= PlanningFailed
| DependentFailed PackageId
| GracefulFailure String
| DownloadFailed SomeException
| UnpackFailed SomeException
| ConfigureFailed SomeException
| BuildFailed SomeException
| TestsFailed SomeException
| InstallFailed SomeException
deriving (Int -> BuildFailure -> ShowS
[BuildFailure] -> ShowS
BuildFailure -> String
(Int -> BuildFailure -> ShowS)
-> (BuildFailure -> String)
-> ([BuildFailure] -> ShowS)
-> Show BuildFailure
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> BuildFailure -> ShowS
showsPrec :: Int -> BuildFailure -> ShowS
$cshow :: BuildFailure -> String
show :: BuildFailure -> String
$cshowList :: [BuildFailure] -> ShowS
showList :: [BuildFailure] -> ShowS
Show, (forall x. BuildFailure -> Rep BuildFailure x)
-> (forall x. Rep BuildFailure x -> BuildFailure)
-> Generic BuildFailure
forall x. Rep BuildFailure x -> BuildFailure
forall x. BuildFailure -> Rep BuildFailure x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cfrom :: forall x. BuildFailure -> Rep BuildFailure x
from :: forall x. BuildFailure -> Rep BuildFailure x
$cto :: forall x. Rep BuildFailure x -> BuildFailure
to :: forall x. Rep BuildFailure x -> BuildFailure
Generic)
instance Exception BuildFailure
data BuildResult
= BuildResult
DocsResult
TestsResult
(Maybe InstalledPackageInfo)
deriving (Int -> BuildResult -> ShowS
[BuildResult] -> ShowS
BuildResult -> String
(Int -> BuildResult -> ShowS)
-> (BuildResult -> String)
-> ([BuildResult] -> ShowS)
-> Show BuildResult
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> BuildResult -> ShowS
showsPrec :: Int -> BuildResult -> ShowS
$cshow :: BuildResult -> String
show :: BuildResult -> String
$cshowList :: [BuildResult] -> ShowS
showList :: [BuildResult] -> ShowS
Show, (forall x. BuildResult -> Rep BuildResult x)
-> (forall x. Rep BuildResult x -> BuildResult)
-> Generic BuildResult
forall x. Rep BuildResult x -> BuildResult
forall x. BuildResult -> Rep BuildResult x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cfrom :: forall x. BuildResult -> Rep BuildResult x
from :: forall x. BuildResult -> Rep BuildResult x
$cto :: forall x. Rep BuildResult x -> BuildResult
to :: forall x. Rep BuildResult x -> BuildResult
Generic)
data DocsResult = DocsNotTried | DocsFailed | DocsOk
deriving (Int -> DocsResult -> ShowS
[DocsResult] -> ShowS
DocsResult -> String
(Int -> DocsResult -> ShowS)
-> (DocsResult -> String)
-> ([DocsResult] -> ShowS)
-> Show DocsResult
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> DocsResult -> ShowS
showsPrec :: Int -> DocsResult -> ShowS
$cshow :: DocsResult -> String
show :: DocsResult -> String
$cshowList :: [DocsResult] -> ShowS
showList :: [DocsResult] -> ShowS
Show, (forall x. DocsResult -> Rep DocsResult x)
-> (forall x. Rep DocsResult x -> DocsResult) -> Generic DocsResult
forall x. Rep DocsResult x -> DocsResult
forall x. DocsResult -> Rep DocsResult x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cfrom :: forall x. DocsResult -> Rep DocsResult x
from :: forall x. DocsResult -> Rep DocsResult x
$cto :: forall x. Rep DocsResult x -> DocsResult
to :: forall x. Rep DocsResult x -> DocsResult
Generic)
data TestsResult = TestsNotTried | TestsOk
deriving (Int -> TestsResult -> ShowS
[TestsResult] -> ShowS
TestsResult -> String
(Int -> TestsResult -> ShowS)
-> (TestsResult -> String)
-> ([TestsResult] -> ShowS)
-> Show TestsResult
forall a.
(Int -> a -> ShowS) -> (a -> String) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> TestsResult -> ShowS
showsPrec :: Int -> TestsResult -> ShowS
$cshow :: TestsResult -> String
show :: TestsResult -> String
$cshowList :: [TestsResult] -> ShowS
showList :: [TestsResult] -> ShowS
Show, (forall x. TestsResult -> Rep TestsResult x)
-> (forall x. Rep TestsResult x -> TestsResult)
-> Generic TestsResult
forall x. Rep TestsResult x -> TestsResult
forall x. TestsResult -> Rep TestsResult x
forall a.
(forall x. a -> Rep a x) -> (forall x. Rep a x -> a) -> Generic a
$cfrom :: forall x. TestsResult -> Rep TestsResult x
from :: forall x. TestsResult -> Rep TestsResult x
$cto :: forall x. Rep TestsResult x -> TestsResult
to :: forall x. Rep TestsResult x -> TestsResult
Generic)
instance Binary BuildFailure
instance Binary BuildResult
instance Binary DocsResult
instance Binary TestsResult
instance Structured BuildFailure
instance Structured BuildResult
instance Structured DocsResult
instance Structured TestsResult