{-# LANGUAGE NoImplicitPrelude #-}
{-# LANGUAGE NoFieldSelectors #-}
{-# LANGUAGE OverloadedRecordDot #-}
module Stack.Types.DumpPackage
( DumpPackage (..)
, SublibDump (..)
, DumpedGlobalPackage
, sublibParentPkgId
) where
import qualified Distribution.License as C
import Distribution.ModuleName ( ModuleName )
import Stack.Prelude
import Stack.Types.Component ( StackUnqualCompName )
import Stack.Types.GhcPkgId ( GhcPkgId )
data DumpPackage = DumpPackage
{ DumpPackage -> GhcPkgId
ghcPkgId :: !GhcPkgId
, DumpPackage -> PackageIdentifier
packageIdent :: !PackageIdentifier
, DumpPackage -> Maybe SublibDump
sublib :: !(Maybe SublibDump)
, DumpPackage -> Maybe License
license :: !(Maybe C.License)
, DumpPackage -> [FilePath]
libDirs :: ![FilePath]
, DumpPackage -> [Text]
libraries :: ![Text]
, DumpPackage -> Bool
hasExposedModules :: !Bool
, DumpPackage -> Set ModuleName
exposedModules :: !(Set ModuleName)
, DumpPackage -> [GhcPkgId]
depends :: ![GhcPkgId]
, DumpPackage -> [FilePath]
haddockInterfaces :: ![FilePath]
, DumpPackage -> Maybe FilePath
haddockHtml :: !(Maybe FilePath)
, DumpPackage -> Bool
isExposed :: !Bool
}
deriving (DumpPackage -> DumpPackage -> Bool
(DumpPackage -> DumpPackage -> Bool)
-> (DumpPackage -> DumpPackage -> Bool) -> Eq DumpPackage
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: DumpPackage -> DumpPackage -> Bool
== :: DumpPackage -> DumpPackage -> Bool
$c/= :: DumpPackage -> DumpPackage -> Bool
/= :: DumpPackage -> DumpPackage -> Bool
Eq, ReadPrec [DumpPackage]
ReadPrec DumpPackage
Int -> ReadS DumpPackage
ReadS [DumpPackage]
(Int -> ReadS DumpPackage)
-> ReadS [DumpPackage]
-> ReadPrec DumpPackage
-> ReadPrec [DumpPackage]
-> Read DumpPackage
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
$creadsPrec :: Int -> ReadS DumpPackage
readsPrec :: Int -> ReadS DumpPackage
$creadList :: ReadS [DumpPackage]
readList :: ReadS [DumpPackage]
$creadPrec :: ReadPrec DumpPackage
readPrec :: ReadPrec DumpPackage
$creadListPrec :: ReadPrec [DumpPackage]
readListPrec :: ReadPrec [DumpPackage]
Read, Int -> DumpPackage -> ShowS
[DumpPackage] -> ShowS
DumpPackage -> FilePath
(Int -> DumpPackage -> ShowS)
-> (DumpPackage -> FilePath)
-> ([DumpPackage] -> ShowS)
-> Show DumpPackage
forall a.
(Int -> a -> ShowS) -> (a -> FilePath) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> DumpPackage -> ShowS
showsPrec :: Int -> DumpPackage -> ShowS
$cshow :: DumpPackage -> FilePath
show :: DumpPackage -> FilePath
$cshowList :: [DumpPackage] -> ShowS
showList :: [DumpPackage] -> ShowS
Show)
data SublibDump = SublibDump
{ SublibDump -> PackageName
packageName :: PackageName
, SublibDump -> StackUnqualCompName
libraryName :: StackUnqualCompName
}
deriving (SublibDump -> SublibDump -> Bool
(SublibDump -> SublibDump -> Bool)
-> (SublibDump -> SublibDump -> Bool) -> Eq SublibDump
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
$c== :: SublibDump -> SublibDump -> Bool
== :: SublibDump -> SublibDump -> Bool
$c/= :: SublibDump -> SublibDump -> Bool
/= :: SublibDump -> SublibDump -> Bool
Eq, ReadPrec [SublibDump]
ReadPrec SublibDump
Int -> ReadS SublibDump
ReadS [SublibDump]
(Int -> ReadS SublibDump)
-> ReadS [SublibDump]
-> ReadPrec SublibDump
-> ReadPrec [SublibDump]
-> Read SublibDump
forall a.
(Int -> ReadS a)
-> ReadS [a] -> ReadPrec a -> ReadPrec [a] -> Read a
$creadsPrec :: Int -> ReadS SublibDump
readsPrec :: Int -> ReadS SublibDump
$creadList :: ReadS [SublibDump]
readList :: ReadS [SublibDump]
$creadPrec :: ReadPrec SublibDump
readPrec :: ReadPrec SublibDump
$creadListPrec :: ReadPrec [SublibDump]
readListPrec :: ReadPrec [SublibDump]
Read, Int -> SublibDump -> ShowS
[SublibDump] -> ShowS
SublibDump -> FilePath
(Int -> SublibDump -> ShowS)
-> (SublibDump -> FilePath)
-> ([SublibDump] -> ShowS)
-> Show SublibDump
forall a.
(Int -> a -> ShowS) -> (a -> FilePath) -> ([a] -> ShowS) -> Show a
$cshowsPrec :: Int -> SublibDump -> ShowS
showsPrec :: Int -> SublibDump -> ShowS
$cshow :: SublibDump -> FilePath
show :: SublibDump -> FilePath
$cshowList :: [SublibDump] -> ShowS
showList :: [SublibDump] -> ShowS
Show)
type DumpedGlobalPackage = DumpPackage
sublibParentPkgId :: DumpPackage -> Maybe PackageIdentifier
sublibParentPkgId :: DumpPackage -> Maybe PackageIdentifier
sublibParentPkgId DumpPackage
dp = DumpPackage
dp.sublib Maybe SublibDump
-> (SublibDump -> PackageIdentifier) -> Maybe PackageIdentifier
forall (f :: * -> *) a b. Functor f => f a -> (a -> b) -> f b
<&> \SublibDump
subLibDump ->
PackageName -> Version -> PackageIdentifier
PackageIdentifier SublibDump
subLibDump.packageName DumpPackage
dp.packageIdent.pkgVersion