diff --git a/ChangeLog.md b/ChangeLog.md index ec3ec43276..f85d756ef8 100644 --- a/ChangeLog.md +++ b/ChangeLog.md @@ -17,7 +17,7 @@ Other enhancements: - Document the way stack interacts with the Cabal library. * `get-stack` script now works on Windows CI machines of Appveyor, Travis and Azure Pipelines. See - [#4535](https://github.com/commercialhaskell/stack/issues/4535)/ + [#4535](https://github.com/commercialhaskell/stack/issues/4535) Bug fixes: @@ -25,6 +25,8 @@ Bug fixes: - Help text for the `templates` subcommand now reflects behaviour in stack 1.9 — that it downloads and shows a help file, rather than listing available templates. - Fix detection of aarch64 platform (this broke when we upgraded to a newer Cabal version). +- Docker: fix detecting and pulling missing images with `--docker-auto-pull`, see + [#4598](https://github.com/commercialhaskell/stack/issues/4598) ## v1.9.3 diff --git a/src/Stack/Build/ConstructPlan.hs b/src/Stack/Build/ConstructPlan.hs index 864fc92497..155c10b3cf 100644 --- a/src/Stack/Build/ConstructPlan.hs +++ b/src/Stack/Build/ConstructPlan.hs @@ -230,8 +230,8 @@ constructPlan ls0 baseConfigOpts0 locals extraToBuild0 localDumpPkgs loadPackage throwM $ ConstructPlanFailed "Plan construction failed." where hasBaseInDeps bconfig = - elem $(mkPackageName "base") - $ map (packageIdentifierName . pirIdent) [i | (PLIndex i) <- bcDependencies bconfig] + $(mkPackageName "base") `elem` + [packageIdentifierName (pirIdent i) | (PLIndex i) <- bcDependencies bconfig] mkCtx econfig = Ctx { ls = ls0 diff --git a/src/Stack/Build/Source.hs b/src/Stack/Build/Source.hs index b4c5777ba1..4dfae000c6 100644 --- a/src/Stack/Build/Source.hs +++ b/src/Stack/Build/Source.hs @@ -328,7 +328,7 @@ checkFlagsUsed boptsCli lps extraDeps snapshot = do -- Check if flags specified in stack.yaml and the command line are -- used, see https://github.com/commercialhaskell/stack/issues/617 - let flags = map (, FSCommandLine) [(k, v) | (Just k, v) <- Map.toList $ boptsCLIFlags boptsCli] + let flags = [((k, v), FSCommandLine) | (Just k, v) <- Map.toList $ boptsCLIFlags boptsCli] ++ map (, FSStackYaml) (Map.toList $ bcFlags bconfig) localNameMap = Map.fromList $ map (packageName . lpPackage &&& lpPackage) lps diff --git a/src/Stack/Docker.hs b/src/Stack/Docker.hs index d660199839..f65610870a 100644 --- a/src/Stack/Docker.hs +++ b/src/Stack/Docker.hs @@ -639,7 +639,10 @@ inspects :: (HasProcessContext env, HasLogFunc env) => [String] -> RIO env (Map String Inspect) inspects [] = return Map.empty inspects images = - do maybeInspectOut <- try (readDockerProcess ("inspect" : images)) + do maybeInspectOut <- + -- not using 'readDockerProcess' as the error from a missing image + -- needs to be recovered. + try (BL.toStrict . fst <$> proc "docker" ("inspect" : images) readProcess_) case maybeInspectOut of Right inspectOut -> -- filtering with 'isAscii' to workaround @docker inspect@ output containing invalid UTF-8 @@ -843,11 +846,16 @@ removeDirectoryContents path excludeDirs excludeFiles = -- | Produce a strict 'S.ByteString' from the stdout of a -- process. Throws a 'ReadProcessException' exception if the --- process fails. Logs process's stderr using @logError@. +-- process fails. +-- +-- The stderr output is passed straight through, which is desirable for some cases +-- e.g. docker pull, in which docker uses stderr for progress output. +-- +-- Use 'readProcess_' directly to customize this. readDockerProcess :: (HasProcessContext env, HasLogFunc env) => [String] -> RIO env BS.ByteString -readDockerProcess args = BL.toStrict <$> proc "docker" args readProcessStdout_ -- FIXME stderr isn't logged with logError, should it be? +readDockerProcess args = BL.toStrict <$> proc "docker" args readProcessStdout_ -- | Name of home directory within docker sandbox. homeDirName :: Path Rel Dir diff --git a/src/Stack/Types/Compiler.hs b/src/Stack/Types/Compiler.hs index f6f9e545de..5c54bfa5db 100644 --- a/src/Stack/Types/Compiler.hs +++ b/src/Stack/Types/Compiler.hs @@ -4,7 +4,6 @@ {-# LANGUAGE DeriveDataTypeable #-} {-# LANGUAGE DeriveGeneric #-} {-# LANGUAGE FlexibleInstances #-} -{-# LANGUAGE KindSignatures #-} {-# LANGUAGE TypeFamilies #-} module Stack.Types.Compiler where