Safe Haskell | None |
---|---|
Language | Haskell2010 |
Dealing with Cabal.
Synopsis
- readDotBuildinfo :: MonadIO m => Path Abs File -> m HookedBuildInfo
- resolvePackage :: PackageConfig -> GenericPackageDescription -> Package
- packageFromPackageDescription :: PackageConfig -> [Flag] -> PackageDescriptionPair -> Package
- data Package = Package {
- packageName :: !PackageName
- packageVersion :: !Version
- packageLicense :: !(Either License License)
- packageFiles :: !GetPackageFiles
- packageDeps :: !(Map PackageName DepValue)
- packageUnknownTools :: !(Set ExeName)
- packageAllDeps :: !(Set PackageName)
- packageGhcOptions :: ![Text]
- packageCabalConfigOpts :: ![Text]
- packageFlags :: !(Map FlagName Bool)
- packageDefaultFlags :: !(Map FlagName Bool)
- packageLibraries :: !PackageLibraries
- packageInternalLibraries :: !(Set Text)
- packageTests :: !(Map Text TestSuiteInterface)
- packageBenchmarks :: !(Set Text)
- packageExes :: !(Set Text)
- packageOpts :: !GetPackageOpts
- packageHasExposedModules :: !Bool
- packageBuildType :: !BuildType
- packageSetupDeps :: !(Maybe (Map PackageName VersionRange))
- packageCabalSpec :: !VersionRange
- data PackageDescriptionPair = PackageDescriptionPair {}
- newtype GetPackageFiles = GetPackageFiles {
- getPackageFiles :: forall env. HasEnvConfig env => Path Abs File -> RIO env (Map NamedComponent (Map ModuleName (Path Abs File)), Map NamedComponent [DotCabalPath], Set (Path Abs File), [PackageWarning])
- newtype GetPackageOpts = GetPackageOpts {
- getPackageOpts :: forall env. HasEnvConfig env => InstallMap -> InstalledMap -> [PackageName] -> [PackageName] -> Path Abs File -> RIO env (Map NamedComponent (Map ModuleName (Path Abs File)), Map NamedComponent [DotCabalPath], Map NamedComponent BuildInfoOpts)
- data PackageConfig = PackageConfig {}
- buildLogPath :: (MonadReader env m, HasBuildConfig env, MonadThrow m) => Package -> Maybe String -> m (Path Abs File)
- data PackageException
- resolvePackageDescription :: PackageConfig -> GenericPackageDescription -> PackageDescriptionPair
- packageDependencies :: PackageConfig -> PackageDescription -> Map PackageName VersionRange
- applyForceCustomBuild :: Version -> Package -> Package
Documentation
readDotBuildinfo :: MonadIO m => Path Abs File -> m HookedBuildInfo Source #
Read package.buildinfo
ancillary files produced by some Setup.hs hooks.
The file includes Cabal file syntax to be merged into the package description
derived from the package's .cabal file.
NOTE: not to be confused with BuildInfo, an Stack-internal datatype.
packageFromPackageDescription :: PackageConfig -> [Flag] -> PackageDescriptionPair -> Package Source #
Some package info.
Package | |
|
data PackageDescriptionPair Source #
A pair of package descriptions: one which modified the buildable values of test suites and benchmarks depending on whether they are enabled, and one which does not.
Fields are intentionally lazy, we may only need one or the other value.
MSS 2017-08-29: The very presence of this data type is terribly ugly, it represents the fact that the Cabal 2.0 upgrade did _not_ go well. Specifically, we used to have a field to indicate whether a component was enabled in addition to buildable, but that's gone now, and this is an ugly proxy. We should at some point clean up the mess of Package, LocalPackage, etc, and probably pull in the definition of PackageDescription from Cabal with our additionally needed metadata. But this is a good enough hack for the moment. Odds are, you're reading this in the year 2024 and thinking "wtf?"
newtype GetPackageFiles Source #
Files that the package depends on, relative to package directory. Argument is the location of the .cabal file
GetPackageFiles | |
|
Instances
Show GetPackageFiles Source # | |
Defined in Stack.Types.Package showsPrec :: Int -> GetPackageFiles -> ShowS # show :: GetPackageFiles -> String # showList :: [GetPackageFiles] -> ShowS # |
newtype GetPackageOpts Source #
Files that the package depends on, relative to package directory. Argument is the location of the .cabal file
GetPackageOpts | |
|
Instances
Show GetPackageOpts Source # | |
Defined in Stack.Types.Package showsPrec :: Int -> GetPackageOpts -> ShowS # show :: GetPackageOpts -> String # showList :: [GetPackageOpts] -> ShowS # |
data PackageConfig Source #
Package build configuration
PackageConfig | |
|
Instances
Show PackageConfig Source # | |
Defined in Stack.Types.Package showsPrec :: Int -> PackageConfig -> ShowS # show :: PackageConfig -> String # showList :: [PackageConfig] -> ShowS # |
buildLogPath :: (MonadReader env m, HasBuildConfig env, MonadThrow m) => Package -> Maybe String -> m (Path Abs File) Source #
Path for the package's build log.
data PackageException Source #
All exceptions thrown by the library.
PackageInvalidCabalFile !(Either PackageIdentifierRevision (Path Abs File)) !(Maybe Version) ![PError] ![PWarning] | |
MismatchedCabalIdentifier !PackageIdentifierRevision !PackageIdentifier |
Instances
Show PackageException Source # | |
Defined in Stack.Types.Package showsPrec :: Int -> PackageException -> ShowS # show :: PackageException -> String # showList :: [PackageException] -> ShowS # | |
Exception PackageException Source # | |
Defined in Stack.Types.Package |
resolvePackageDescription :: PackageConfig -> GenericPackageDescription -> PackageDescriptionPair Source #
Evaluates the conditions of a GenericPackageDescription
, yielding
a resolved PackageDescription
.
packageDependencies :: PackageConfig -> PackageDescription -> Map PackageName VersionRange Source #
Get all dependencies of the package (buildable targets only).
Note that for Cabal versions 1.22 and earlier, there is a bug where Cabal requires dependencies for non-buildable components to be present. We're going to use GHC version as a proxy for Cabal library version in this case for simplicity, so we'll check for GHC being 7.10 or earlier. This obviously makes our function a lot more fun to write...
applyForceCustomBuild Source #
Force a package to be treated as a custom build type, see https://github.com/commercialhaskell/stack/issues/4488