Skip to content

Commit

Permalink
Merge pull request #9875 from haskell/mergify/bp/3.12/pr-9719
Browse files Browse the repository at this point in the history
Fix cabal install in the presence of extra-packages (backport #9719)
  • Loading branch information
mergify[bot] authored Apr 10, 2024
2 parents 5ab8bf8 + f5e8e60 commit b5ac2f7
Show file tree
Hide file tree
Showing 5 changed files with 30 additions and 5 deletions.
18 changes: 13 additions & 5 deletions cabal-install/src/Distribution/Client/CmdInstall.hs
Original file line number Diff line number Diff line change
Expand Up @@ -470,8 +470,7 @@ installAction flags@NixStyleFlags{extraFlags, configFlags, installFlags, project

-- check for targets already in env
let getPackageName :: PackageSpecifier UnresolvedSourcePackage -> PackageName
getPackageName (NamedPackage pn _) = pn
getPackageName (SpecificSourcePackage (SourcePackage pkgId _ _ _)) = pkgName pkgId
getPackageName = pkgSpecifierTarget
targetNames = S.fromList $ map getPackageName (pkgSpecs ++ uriSpecs)
envNames = S.fromList $ map getPackageName envSpecs
forceInstall = fromFlagOrDefault False $ installOverrideReinstall installFlags
Expand Down Expand Up @@ -571,7 +570,7 @@ withProject verbosity cliConfig targetStrings installLibs = do
if null unresolvedTargetStrings
then return (parsedPkgSpecs, parsedTargets)
else do
-- Anything that could not be parsed as a packageId (e.g. a pacakge name with not version or
-- Anything that could not be parsed as a packageId (e.g. a package name without a version or
-- a target syntax using colons) must be resolved inside the project context.
(resolvedPkgSpecs, resolvedTargets) <-
resolveTargetSelectorsInProjectBaseContext verbosity baseCtx unresolvedTargetStrings targetFilter
Expand All @@ -580,7 +579,7 @@ withProject verbosity cliConfig targetStrings installLibs = do
-- Apply the local configuration (e.g. cli flags) to all direct targets of install command, see note
-- in 'installAction'.
--
-- NOTE: If a target string had to be resolved inside the project conterxt, then pkgSpecs will include
-- NOTE: If a target string had to be resolved inside the project context, then pkgSpecs will include
-- the project packages turned into source distributions (getSpecsAndTargetSelectors does this).
-- We want to apply the local configuration only to the actual targets.
let config =
Expand Down Expand Up @@ -797,7 +796,16 @@ getSpecsAndTargetSelectors verbosity reducedVerbosity sourcePkgDb targetSelector
TarGzArchive
(distSdistFile distDirLayout (packageId pkg))
pkg
NamedPackage pkgName _ -> error $ "Got NamedPackage " ++ prettyShow pkgName
NamedPackage _ _ ->
-- This may happen if 'extra-packages' are listed in the project file.
-- We don't need to do extra work for NamedPackages since they will be
-- fetched from Hackage rather than locally 'sdistize'-d. Note how,
-- below, we already return the local 'sdistize'-d packages together
-- with the 'hackagePkgs' (which are 'NamedPackage's), and that
-- 'sdistize' is a no-op for 'NamedPackages', meaning the
-- 'NamedPackage's in 'localPkgs' will be treated just like
-- 'hackagePkgs' as they should.
pure ()

if null targetsMap
then return (hackagePkgs, hackageTargets)
Expand Down
1 change: 1 addition & 0 deletions cabal-testsuite/PackageTests/Install/T8848/Main.hs
Original file line number Diff line number Diff line change
@@ -0,0 +1 @@
main = pure ()
2 changes: 2 additions & 0 deletions cabal-testsuite/PackageTests/Install/T8848/cabal.project
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
packages: .
extra-packages: containers
6 changes: 6 additions & 0 deletions cabal-testsuite/PackageTests/Install/T8848/cabal.test.hs
Original file line number Diff line number Diff line change
@@ -0,0 +1,6 @@
import Test.Cabal.Prelude

main = cabalTest $ do
recordMode DoNotRecord $
cabal' "install" ["t8848"]
>>= assertOutputContains "Wrote tarball sdist to"
8 changes: 8 additions & 0 deletions cabal-testsuite/PackageTests/Install/T8848/t8848.cabal
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
name: t8848
version: 1.0
build-type: Simple
cabal-version: >= 1.2

executable t8848
main-is: Main.hs
build-depends: base

0 comments on commit b5ac2f7

Please sign in to comment.