From 193f49da018c7f91cf551f4cd606abb9ba4b3da5 Mon Sep 17 00:00:00 2001 From: "Edward Z. Yang" Date: Wed, 20 Jul 2016 23:47:43 -0700 Subject: [PATCH] finalizePackageDescription BC. Signed-off-by: Edward Z. Yang --- Cabal/Distribution/PackageDescription.hs | 2 +- .../Distribution/PackageDescription/Check.hs | 4 ++-- .../PackageDescription/Configuration.hs | 21 ++++++++++++++++--- Cabal/Distribution/Simple/Configure.hs | 10 ++++----- Cabal/changelog | 8 ++++--- .../Distribution/Client/Configure.hs | 6 +++--- .../Distribution/Client/Dependency.hs | 6 +++--- .../Distribution/Client/Dependency/TopDown.hs | 6 +++--- .../Distribution/Client/GenBounds.hs | 6 +++--- cabal-install/Distribution/Client/Install.hs | 6 +++--- .../Distribution/Client/InstallSymlink.hs | 6 +++--- .../Distribution/Client/ProjectPlanning.hs | 2 +- .../Solver/Modular/IndexConversion.hs | 2 +- .../Distribution/Solver/Modular/DSL.hs | 2 +- 14 files changed, 52 insertions(+), 35 deletions(-) diff --git a/Cabal/Distribution/PackageDescription.hs b/Cabal/Distribution/PackageDescription.hs index 3310a840d23..fd745299728 100644 --- a/Cabal/Distribution/PackageDescription.hs +++ b/Cabal/Distribution/PackageDescription.hs @@ -174,7 +174,7 @@ data PackageDescription -- PackageDescription we are, the contents of this field are -- either nonsense, or the collected dependencies of *all* the -- components in this package. buildDepends is initialized by - -- 'finalizePackageDescription' and 'flattenPackageDescription'; + -- 'finalizePD' and 'flattenPackageDescription'; -- prior to that, dependency info is stored in the 'CondTree' -- built around a 'GenericPackageDescription'. When this -- resolution is done, dependency info is written to the inner diff --git a/Cabal/Distribution/PackageDescription/Check.hs b/Cabal/Distribution/PackageDescription/Check.hs index 8f7187798ff..c9e024aae21 100644 --- a/Cabal/Distribution/PackageDescription/Check.hs +++ b/Cabal/Distribution/PackageDescription/Check.hs @@ -1283,7 +1283,7 @@ checkPackageVersions pkg = -- pick a single "typical" configuration and check if that has an -- open upper bound. To get a typical configuration we finalise -- using no package index and the current platform. - finalised = finalizePackageDescription + finalised = finalizePD [] defaultComponentEnabled (const True) buildPlatform (unknownCompilerInfo (CompilerId buildCompilerFlavor (Version [] [])) NoAbiTag) @@ -1295,7 +1295,7 @@ checkPackageVersions pkg = baseDeps = [ vr | Dependency (PackageName "base") vr <- buildDepends pkg' ] - -- Just in case finalizePackageDescription fails for any reason, + -- Just in case finalizePD fails for any reason, -- or if the package doesn't depend on the base package at all, -- then we will just skip the check, since boundedAbove noVersion = True _ -> noVersion diff --git a/Cabal/Distribution/PackageDescription/Configuration.hs b/Cabal/Distribution/PackageDescription/Configuration.hs index 643f4ed2410..cd5e9b740f5 100644 --- a/Cabal/Distribution/PackageDescription/Configuration.hs +++ b/Cabal/Distribution/PackageDescription/Configuration.hs @@ -11,12 +11,13 @@ -- Portability : portable -- -- This is about the cabal configurations feature. It exports --- 'finalizePackageDescription' and 'flattenPackageDescription' which are +-- 'finalizePD' and 'flattenPackageDescription' which are -- functions for converting 'GenericPackageDescription's down to -- 'PackageDescription's. It has code for working with the tree of conditions -- and resolving or flattening conditions. module Distribution.PackageDescription.Configuration ( + finalizePD, finalizePackageDescription, flattenPackageDescription, @@ -553,7 +554,7 @@ instance Semigroup PDTagged where -- On success, it will return the package description and the full flag -- assignment chosen. -- -finalizePackageDescription :: +finalizePD :: FlagAssignment -- ^ Explicitly specified flag assignments -> ComponentEnabledSpec -> (Dependency -> Bool) -- ^ Is a given dependency satisfiable from the set of @@ -567,7 +568,7 @@ finalizePackageDescription :: (PackageDescription, FlagAssignment) -- ^ Either missing dependencies or the resolved package -- description along with the flag assignments chosen. -finalizePackageDescription userflags enabled satisfyDep +finalizePD userflags enabled satisfyDep (Platform arch os) impl constraints (GenericPackageDescription pkg flags libs0 exes0 tests0 bms0) = case resolveFlags of @@ -611,6 +612,20 @@ finalizePackageDescription userflags enabled satisfyDep then DepOk else MissingDeps missingDeps +{-# DEPRECATED finalizePackageDescription "This function now always assumes tests and benchmarks are disabled; use finalizePD with ComponentEnabledSpec to specify something more specific." #-} +finalizePackageDescription :: + FlagAssignment -- ^ Explicitly specified flag assignments + -> (Dependency -> Bool) -- ^ Is a given dependency satisfiable from the set of + -- available packages? If this is unknown then use + -- True. + -> Platform -- ^ The 'Arch' and 'OS' + -> CompilerInfo -- ^ Compiler information + -> [Dependency] -- ^ Additional constraints + -> GenericPackageDescription + -> Either [Dependency] + (PackageDescription, FlagAssignment) +finalizePackageDescription flags = finalizePD flags defaultComponentEnabled + {- let tst_p = (CondNode [1::Int] [Distribution.Package.Dependency "a" AnyVersion] []) let tst_p2 = (CondNode [1::Int] [Distribution.Package.Dependency "a" (EarlierVersion (Version [1,0] [])), Distribution.Package.Dependency "a" (LaterVersion (Version [2,0] []))] []) diff --git a/Cabal/Distribution/Simple/Configure.hs b/Cabal/Distribution/Simple/Configure.hs index 94dc3adc17c..377d139ce07 100644 --- a/Cabal/Distribution/Simple/Configure.hs +++ b/Cabal/Distribution/Simple/Configure.hs @@ -807,7 +807,7 @@ checkExactConfiguration pkg_descr0 cfg = do -- -- It must be *any libraries that might be* defined rather than the -- actual definitions, because these depend on conditionals in the .cabal --- file, and we haven't resolved them yet. finalizePackageDescription +-- file, and we haven't resolved them yet. finalizePD -- does the resolution of conditionals, and it takes internalPackageSet -- as part of its input. getInternalPackages :: GenericPackageDescription @@ -832,7 +832,7 @@ getInternalPackages pkg_descr0 = -- | Returns true if a dependency is satisfiable. This is to be passed --- to finalizePackageDescription. +-- to finalizePD. dependencySatisfiable :: Bool -> InstalledPackageIndex -- ^ installed set @@ -848,7 +848,7 @@ dependencySatisfiable -- line. Thus we only consult the 'requiredDepsMap'. Note that -- we're not doing the version range check, so if there's some -- dependency that wasn't specified on the command line, - -- 'finalizePackageDescription' will fail. + -- 'finalizePD' will fail. -- -- TODO: mention '--exact-configuration' in the error message -- when this fails? @@ -891,7 +891,7 @@ relaxPackageDeps (RelaxDepsSome allowNewerDeps') gpd = else d -- | Finalize a generic package description. The workhorse is --- 'finalizePackageDescription' but there's a bit of other nattering +-- 'finalizePD' but there's a bit of other nattering -- about necessary. -- -- TODO: what exactly is the business with @flaggedTests@ and @@ -911,7 +911,7 @@ configureFinalizedPackage verbosity cfg enabled allConstraints satisfies comp compPlatform pkg_descr0 = do (pkg_descr0', flags) <- - case finalizePackageDescription + case finalizePD (configConfigurationsFlags cfg) enabled satisfies diff --git a/Cabal/changelog b/Cabal/changelog index 2ef09697a93..a3e90a2e6cd 100644 --- a/Cabal/changelog +++ b/Cabal/changelog @@ -33,11 +33,13 @@ such components, regardless of whether or not they have been enabled; if you only want enabled components, use 'withTestLBI' and 'withBenchLBI'. - 'componentEnabled', 'enabledComponents' and - 'finalizePackageDescription' now takes an extra argument + 'finalizePackageDescription' is deprecated: + its replacement 'finalizePD' now takes an extra argument 'ComponentEnabledSpec' which specifies what components are to be enabled: use this instead of modifying the - 'Component' in a 'GenericPackageDescription'. + 'Component' in a 'GenericPackageDescription'. (As + it's not possible now, 'finalizePackageDescription' + will assume tests/benchmarks are disabled.) If you only need to test if a component is buildable (i.e., it is marked buildable in the Cabal file) use the new function 'componentBuildable'. diff --git a/cabal-install/Distribution/Client/Configure.hs b/cabal-install/Distribution/Client/Configure.hs index 31000b18861..aaf77db405e 100644 --- a/cabal-install/Distribution/Client/Configure.hs +++ b/cabal-install/Distribution/Client/Configure.hs @@ -62,7 +62,7 @@ import qualified Distribution.PackageDescription as PkgDesc import Distribution.PackageDescription.Parse ( readPackageDescription ) import Distribution.PackageDescription.Configuration - ( finalizePackageDescription ) + ( finalizePD ) import Distribution.Version ( anyVersion, thisVersion ) import Distribution.Simple.Utils as Utils @@ -386,8 +386,8 @@ configurePackage verbosity platform comp scriptOptions configFlags configTests = toFlag (TestStanzas `elem` stanzas) } - pkg = case finalizePackageDescription flags (enableStanzas stanzas) + pkg = case finalizePD flags (enableStanzas stanzas) (const True) platform comp [] gpkg of - Left _ -> error "finalizePackageDescription ReadyPackage failed" + Left _ -> error "finalizePD ReadyPackage failed" Right (desc, _) -> desc diff --git a/cabal-install/Distribution/Client/Dependency.hs b/cabal-install/Distribution/Client/Dependency.hs index 565cc92dbe5..02d19898f9d 100644 --- a/cabal-install/Distribution/Client/Dependency.hs +++ b/cabal-install/Distribution/Client/Dependency.hs @@ -89,7 +89,7 @@ import Distribution.Package import qualified Distribution.PackageDescription as PD import qualified Distribution.PackageDescription.Configuration as PD import Distribution.PackageDescription.Configuration - ( finalizePackageDescription ) + ( finalizePD ) import Distribution.Client.PackageUtils ( externalBuildDepends ) import Distribution.Version @@ -847,8 +847,8 @@ configuredPackageProblems platform cinfo -- of the `nubOn` in `mergeDeps`. requiredDeps :: [Dependency] requiredDeps = - --TODO: use something lower level than finalizePackageDescription - case finalizePackageDescription specifiedFlags + --TODO: use something lower level than finalizePD + case finalizePD specifiedFlags (enableStanzas stanzas) (const True) platform cinfo diff --git a/cabal-install/Distribution/Client/Dependency/TopDown.hs b/cabal-install/Distribution/Client/Dependency/TopDown.hs index 3004bdfbf34..baf47f1bc8a 100644 --- a/cabal-install/Distribution/Client/Dependency/TopDown.hs +++ b/cabal-install/Distribution/Client/Dependency/TopDown.hs @@ -36,7 +36,7 @@ import Distribution.PackageDescription import Distribution.Client.PackageUtils ( externalBuildDepends ) import Distribution.PackageDescription.Configuration - ( finalizePackageDescription, flattenPackageDescription ) + ( finalizePD, flattenPackageDescription ) import Distribution.Version ( Version(..), VersionRange, withinRange, simplifyVersionRange , UpperBound(..), asVersionIntervals ) @@ -396,7 +396,7 @@ pruneBottomUp platform comp constraints = | dep <- missing ] configure cs (UnconfiguredPackage (SourcePackage _ pkg _ _) _ flags stanzas) = - finalizePackageDescription flags (enableStanzas stanzas) (dependencySatisfiable cs) + finalizePD flags (enableStanzas stanzas) (dependencySatisfiable cs) platform comp [] pkg dependencySatisfiable cs = not . null . PackageIndex.lookupDependency (Constraints.choices cs) @@ -425,7 +425,7 @@ configurePackage platform cinfo available spkg = case spkg of (configure apkg) where configure (UnconfiguredPackage apkg@(SourcePackage _ p _ _) _ flags stanzas) = - case finalizePackageDescription flags (enableStanzas stanzas) dependencySatisfiable + case finalizePD flags (enableStanzas stanzas) dependencySatisfiable platform cinfo [] p of Left missing -> Left missing Right (pkg, flags') -> Right $ diff --git a/cabal-install/Distribution/Client/GenBounds.hs b/cabal-install/Distribution/Client/GenBounds.hs index e554004be7a..cbcb3275d27 100644 --- a/cabal-install/Distribution/Client/GenBounds.hs +++ b/cabal-install/Distribution/Client/GenBounds.hs @@ -30,7 +30,7 @@ import Distribution.Package import Distribution.PackageDescription ( buildDepends ) import Distribution.PackageDescription.Configuration - ( finalizePackageDescription ) + ( finalizePD ) import Distribution.PackageDescription.Parse ( readPackageDescription ) import Distribution.Simple.LocalBuildInfo @@ -111,10 +111,10 @@ genBounds verbosity packageDBs repoCtxt comp platform conf mSandboxPkgInfo gpd <- readPackageDescription verbosity path -- NB: We don't enable tests or benchmarks, since often they -- don't really have useful bounds. - let epd = finalizePackageDescription [] defaultComponentEnabled + let epd = finalizePD [] defaultComponentEnabled (const True) platform cinfo [] gpd case epd of - Left _ -> putStrLn "finalizePackageDescription failed" + Left _ -> putStrLn "finalizePD failed" Right (pd,_) -> do let needBounds = filter (not . hasUpperBound . depVersion) $ buildDepends pd diff --git a/cabal-install/Distribution/Client/Install.hs b/cabal-install/Distribution/Client/Install.hs index 61cf18bd7e6..f1211cac829 100644 --- a/cabal-install/Distribution/Client/Install.hs +++ b/cabal-install/Distribution/Client/Install.hs @@ -159,7 +159,7 @@ import Distribution.PackageDescription ( PackageDescription, GenericPackageDescription(..), Flag(..) , FlagName(..), FlagAssignment ) import Distribution.PackageDescription.Configuration - ( finalizePackageDescription ) + ( finalizePD ) import Distribution.ParseUtils ( showPWarning ) import Distribution.Version @@ -1302,10 +1302,10 @@ installReadyPackage platform cinfo configFlags configTests = toFlag (TestStanzas `elem` stanzas) } source pkg pkgoverride where - pkg = case finalizePackageDescription flags (enableStanzas stanzas) + pkg = case finalizePD flags (enableStanzas stanzas) (const True) platform cinfo [] gpkg of - Left _ -> error "finalizePackageDescription ReadyPackage failed" + Left _ -> error "finalizePD ReadyPackage failed" Right (desc, _) -> desc fetchSourcePackage diff --git a/cabal-install/Distribution/Client/InstallSymlink.hs b/cabal-install/Distribution/Client/InstallSymlink.hs index 0025a7605e2..692c4e25e49 100644 --- a/cabal-install/Distribution/Client/InstallSymlink.hs +++ b/cabal-install/Distribution/Client/InstallSymlink.hs @@ -56,7 +56,7 @@ import qualified Distribution.PackageDescription as PackageDescription import Distribution.PackageDescription ( PackageDescription ) import Distribution.PackageDescription.Configuration - ( finalizePackageDescription ) + ( finalizePD ) import Distribution.Simple.Setup ( ConfigFlags(..), fromFlag, fromFlagOrDefault, flagToMaybe ) import qualified Distribution.Simple.InstallDirs as InstallDirs @@ -145,10 +145,10 @@ symlinkBinaries platform comp configFlags installFlags plan = pkgDescription (ReadyPackage (ConfiguredPackage _ (SourcePackage _ pkg _ _) flags stanzas _)) = - case finalizePackageDescription flags (enableStanzas stanzas) + case finalizePD flags (enableStanzas stanzas) (const True) platform cinfo [] pkg of - Left _ -> error "finalizePackageDescription ReadyPackage failed" + Left _ -> error "finalizePD ReadyPackage failed" Right (desc, _) -> desc -- This is sadly rather complicated. We're kind of re-doing part of the diff --git a/cabal-install/Distribution/Client/ProjectPlanning.hs b/cabal-install/Distribution/Client/ProjectPlanning.hs index 62239ae2702..fd642f8ad6c 100644 --- a/cabal-install/Distribution/Client/ProjectPlanning.hs +++ b/cabal-install/Distribution/Client/ProjectPlanning.hs @@ -1065,7 +1065,7 @@ elaborateInstallPlan platform compiler compilerprogdb -- pkgSourceId = pkgid pkgDescription = let Right (desc, _) = - PD.finalizePackageDescription + PD.finalizePD flags enabled (const True) platform (compilerInfo compiler) [] gdesc diff --git a/cabal-install/Distribution/Solver/Modular/IndexConversion.hs b/cabal-install/Distribution/Solver/Modular/IndexConversion.hs index 69aeb75fa5b..f7620555f6e 100644 --- a/cabal-install/Distribution/Solver/Modular/IndexConversion.hs +++ b/cabal-install/Distribution/Solver/Modular/IndexConversion.hs @@ -101,7 +101,7 @@ convSP os arch cinfo strfl (SourcePackage (PackageIdentifier pn pv) gpd _ _pl) = let i = I pv InRepo in (pn, i, convGPD os arch cinfo strfl (PI pn i) gpd) --- We do not use 'flattenPackageDescription' or 'finalizePackageDescription' +-- We do not use 'flattenPackageDescription' or 'finalizePD' -- from 'Distribution.PackageDescription.Configuration' here, because we -- want to keep the condition tree, but simplify much of the test. diff --git a/cabal-install/tests/UnitTests/Distribution/Solver/Modular/DSL.hs b/cabal-install/tests/UnitTests/Distribution/Solver/Modular/DSL.hs index 4a08f0649c2..1afb1bb79ea 100644 --- a/cabal-install/tests/UnitTests/Distribution/Solver/Modular/DSL.hs +++ b/cabal-install/tests/UnitTests/Distribution/Solver/Modular/DSL.hs @@ -89,7 +89,7 @@ import Distribution.Solver.Types.Variable `GenericPackageDescription` can be turned into a `PackageDescription` in two ways: - a. `finalizePackageDescription` does the proper translation, by taking + a. `finalizePD` does the proper translation, by taking into account the platform, available dependencies, etc. and picks a flag assignment (or gives an error if no flag assignment can be found) b. `flattenPackageDescription` ignores flag assignment and just joins all