Cabal-ide-backend-1.23.0.0: A framework for packaging Haskell software

CopyrightIsaac Jones 2003-2005
LicenseBSD3
Maintainercabal-devel@haskell.org
Portabilityportable
Safe HaskellNone
LanguageHaskell98

Distribution.Simple.Configure

Description

This deals with the configure phase. It provides the configure action which is given the package description and configure flags. It then tries to: configure the compiler; resolves any conditionals in the package description; resolve the package dependencies; check if all the extensions used by this package are supported by the compiler; check that all the build tools are available (including version checks if appropriate); checks for any required pkg-config packages (updating the BuildInfo with the results)

Then based on all this it saves the info in the LocalBuildInfo and writes it out to the dist/setup-config file. It also displays various details to the user, the amount of information displayed depending on the verbosity level.

Synopsis

Documentation

configure :: (GenericPackageDescription, HookedBuildInfo) -> ConfigFlags -> IO LocalBuildInfo Source

Perform the "./setup configure" action. Returns the .setup-config file.

writePersistBuildConfig Source

Arguments

:: FilePath

The dist directory path.

-> LocalBuildInfo

The LocalBuildInfo to write.

-> IO () 

After running configure, output the LocalBuildInfo to the localBuildInfoFile.

getConfigStateFile Source

Arguments

:: FilePath

The file path of the setup-config file.

-> IO LocalBuildInfo 

Read the localBuildInfoFile. Throw an exception if the file is missing, if the file cannot be read, or if the file was created by an older version of Cabal.

getPersistBuildConfig Source

Arguments

:: FilePath

The dist directory path.

-> IO LocalBuildInfo 

Read the localBuildInfoFile. Throw an exception if the file is missing, if the file cannot be read, or if the file was created by an older version of Cabal.

checkPersistBuildConfigOutdated :: FilePath -> FilePath -> IO Bool Source

Check that localBuildInfoFile is up-to-date with respect to the .cabal file.

maybeGetPersistBuildConfig Source

Arguments

:: FilePath

The dist directory path.

-> IO (Maybe LocalBuildInfo) 

Try to read the localBuildInfoFile.

localBuildInfoFile Source

Arguments

:: FilePath

The dist directory path.

-> FilePath 

Get the path of dist/setup-config.

getInstalledPackages Source

Arguments

:: Verbosity 
-> Compiler 
-> PackageDBStack

The stack of package databases.

-> ProgramConfiguration 
-> IO InstalledPackageIndex 

List all installed packages in the given package databases.

configCompilerAux :: ConfigFlags -> IO (Compiler, ProgramConfiguration) Source

Deprecated: configCompilerAux is deprecated. Use configCompilerAuxEx instead.

ccLdOptionsBuildInfo :: [String] -> [String] -> BuildInfo Source

Makes a BuildInfo from C compiler and linker flags.

This can be used with the output from configuration programs like pkg-config and similar package-specific programs like mysql-config, freealut-config etc. For example:

ccflags <- rawSystemProgramStdoutConf verbosity prog conf ["--cflags"]
ldflags <- rawSystemProgramStdoutConf verbosity prog conf ["--libs"]
return (ccldOptionsBuildInfo (words ccflags) (words ldflags))

interpretPackageDbFlags :: Bool -> [Maybe PackageDB] -> PackageDBStack Source

The user interface specifies the package dbs to use with a combination of --global, --user and --package-db=global|user|clear|$file. This function combines the global/user flag and interprets the package-db flag into a single package db stack.

tryGetConfigStateFile Source

Arguments

:: FilePath

The file path of the setup-config file.

-> IO (Either ConfigStateFileError LocalBuildInfo) 

Read the localBuildInfoFile, returning either an error or the local build info.