Skip to content

Commit

Permalink
Add a warning when an env file is created
Browse files Browse the repository at this point in the history
  • Loading branch information
tomsmeding committed Feb 12, 2024
1 parent 0a0b339 commit cf08c6f
Showing 1 changed file with 31 additions and 10 deletions.
41 changes: 31 additions & 10 deletions cabal-install/src/Distribution/Client/CmdInstall.hs
Original file line number Diff line number Diff line change
Expand Up @@ -537,7 +537,7 @@ installAction flags@NixStyleFlags{extraFlags = clientInstallFlags', ..} targetSt
GhcImplInfo{supportsPkgEnvFiles} = getImplInfo compiler

envFile <- getEnvFile clientInstallFlags platform compilerVersion
existingEnvEntries <-
(usedExistingPkgEnvFile, existingEnvEntries) <-
getExistingEnvEntries verbosity compilerFlavor supportsPkgEnvFiles envFile
packageDbs <- getPackageDbStack compiler projectConfigStoreDir projectConfigLogsDir
installedIndex <- getInstalledPackages verbosity compiler packageDbs progDb
Expand Down Expand Up @@ -628,6 +628,7 @@ installAction flags@NixStyleFlags{extraFlags = clientInstallFlags', ..} targetSt
packageDbs
envFile
nonGlobalEnvEntries'
usedExistingPkgEnvFile
else -- Install any built exe by symlinking or copying it we don't use
-- BuildOutcomes because we also need the component names
traverseInstall (installCheckUnitExes InstallCheckInstall) installCfg
Expand Down Expand Up @@ -909,6 +910,8 @@ installLibraries
-> FilePath
-- ^ Environment file
-> [GhcEnvironmentFileEntry]
-> Bool
-- ^ Whether we used an existing environment file (for diagnostics)
-> IO ()
installLibraries
verbosity
Expand All @@ -917,7 +920,8 @@ installLibraries
compiler
packageDbs'
envFile
envEntries = do
envEntries
usedExistingPkgEnvFile = do
if supportsPkgEnvFiles $ getImplInfo compiler
then do
let validDb (SpecificPackageDB fp) = doesPathExist fp
Expand All @@ -943,6 +947,21 @@ installLibraries
contents' = renderGhcEnvironmentFile (baseEntries ++ pkgEntries)
createDirectoryIfMissing True (takeDirectory envFile)
writeFileAtomic envFile (BS.pack contents')
unless usedExistingPkgEnvFile $
warn verbosity $
"The libraries were installed by creating a global GHC environment file at:\n"
++ " " ++ envFile ++ "\n"
++ "The presence of such an environment file has several knock-on effects. Because\n"
++ "changes the default package set in ghc and ghci from their default (which is\n"
++ "\"all boot libraries\"), and because GHC environment files are little-used, other\n"
++ "tools are likely to be confused by GHC's behaviour in the presence of this file.\n"
++ "\n"
++ "Double-check that creating a global GHC environment file is really what you\n"
++ "wanted! You can also limit the effects by creating a GHC environment file in a\n"
++ "specific directory only using the --package-env flag, for example:\n"
++ " cabal install --lib <packages...> --package-env .\n"
++ "to create the file in the current directory, and so limit its potentially\n"
++ "harmful effects."
else
warn verbosity $
"The current compiler doesn't support safely installing libraries, "
Expand Down Expand Up @@ -1195,24 +1214,26 @@ getEnvFile clientInstallFlags platform compilerVersion = do
Nothing ->
return (getGlobalEnv appDir platform compilerVersion "default")

-- | Returns the list of @GhcEnvFilePackageIj@ values already existing in the
-- environment being operated on.
getExistingEnvEntries :: Verbosity -> CompilerFlavor -> Bool -> FilePath -> IO [GhcEnvironmentFileEntry]
-- | Returns the list of @GhcEnvFilePackageId@ values already existing in the
-- environment being operated on. The @Bool@ is @True@ if we took settings
-- from an existing file, @False@ otherwise.
getExistingEnvEntries :: Verbosity -> CompilerFlavor -> Bool -> FilePath -> IO (Bool, [GhcEnvironmentFileEntry])
getExistingEnvEntries verbosity compilerFlavor supportsPkgEnvFiles envFile = do
envFileExists <- doesFileExist envFile
filterEnvEntries
<$> if (compilerFlavor == GHC || compilerFlavor == GHCJS)
(usedExisting, allEntries) <-
if (compilerFlavor == GHC || compilerFlavor == GHCJS)
&& supportsPkgEnvFiles
&& envFileExists
then catch (readGhcEnvironmentFile envFile) $ \(_ :: ParseErrorExc) ->
then catch ((True,) <$> readGhcEnvironmentFile envFile) $ \(_ :: ParseErrorExc) ->
warn
verbosity
( "The environment file "
++ envFile
++ " is unparsable. Libraries cannot be installed."
)
>> return []
else return []
>> return (False, [])
else return (False, [])
return (usedExisting, filterEnvEntries allEntries)
where
-- Why? We know what the first part will be, we only care about the packages.
filterEnvEntries = filter $ \case
Expand Down

0 comments on commit cf08c6f

Please sign in to comment.