Skip to content

Commit

Permalink
Re #6379 Better information about manual installation
Browse files Browse the repository at this point in the history
  • Loading branch information
mpilgrem committed Dec 24, 2023
1 parent f75549f commit 332f35a
Showing 1 changed file with 54 additions and 20 deletions.
74 changes: 54 additions & 20 deletions src/Stack/Setup.hs
Original file line number Diff line number Diff line change
Expand Up @@ -158,7 +158,8 @@ import Stack.Types.Platform
, platformOnlyRelDir )
import Stack.Types.Runner ( HasRunner (..) )
import Stack.Types.SetupInfo ( SetupInfo (..) )
import Stack.Types.SourceMap ( SMActual (..), SourceMap (..) )
import Stack.Types.SourceMap
( SMActual (..), SMWanted (..), SourceMap (..) )
import Stack.Types.Version
( VersionCheck, stackMinorVersion, stackVersion )
import Stack.Types.VersionedDownloadInfo
Expand Down Expand Up @@ -198,7 +199,7 @@ data SetupPrettyException
| InvalidGhcAt !(Path Abs File) !SomeException
| ExecutableNotFound ![Path Abs File]
| SandboxedCompilerNotFound ![String] ![Path Abs Dir]
| UnsupportedSetupCombo !OS !Arch
| UnsupportedSetupCombo !OS !Arch !StyleDoc !(Path Rel Dir) !(Path Abs Dir)
| MissingDependencies ![String]
| UnknownCompilerVersion
!(Set.Set Text)
Expand Down Expand Up @@ -310,17 +311,34 @@ instance Pretty SetupPrettyException where
\tools, see the output of"
, style Shell (flow "stack uninstall") <> "."
]
pretty (UnsupportedSetupCombo os arch) =
pretty (UnsupportedSetupCombo os arch tool toolDir programsDir) =
"[S-1852]"
<> line
<> fillSep
[ flow "Stack does not know how to install GHC for the combination of \
\operating system"
[ flow "Stack does not know how to install"
, tool
, flow "for the combination of operating system"
, style Shell (pretty os)
, "and architecture"
, style Shell (pretty arch) <> "."
, flow "Please install manually."
]
<> blankLine
<> fillSep
[ flow "To install manually the version of"
, tool <> ","
, flow "its root directory should be named"
, pretty toolDir
, flow "and the directory should be accompanied by a file with the \
\same name and extension"
, style File ".installed"
, flow "(which marks the"
, tool
, flow "version as installed). Both items should be located in the \
\subdirectory for the specified platform in Stack's directory \
\for local tools"
, parens (pretty programsDir) <> "."
]
pretty (MissingDependencies tools) =
"[S-2126]"
<> line
Expand Down Expand Up @@ -1081,7 +1099,8 @@ ensureMsys sopts getSetupInfo' = do
Nothing
| soptsInstallIfMissing sopts -> do
si <- runMemoized getSetupInfo'
osKey <- getOSKey platform
msysDir <- parseRelDir "msys2-yyyymmdd"
osKey <- getOSKey "MSYS2" msysDir
config <- view configL
VersionedDownloadInfo version info <-
case Map.lookup osKey $ siMsys2 si of
Expand All @@ -1094,7 +1113,7 @@ ensureMsys sopts getSetupInfo' = do
tool
(installMsys2Windows si)
| otherwise -> do
prettyWarnS "Continuing despite missing tool: msys2"
prettyWarnS "Continuing despite missing tool: MSYS2."
pure Nothing
_ -> pure Nothing

Expand Down Expand Up @@ -2065,23 +2084,37 @@ downloadAndInstallPossibleCompilers possibleCompilers si wanted versionCheck mbi
Right r -> pure (r, b)

getGhcKey ::
(MonadReader env m, HasPlatform env, HasGHCVariant env, MonadThrow m)
(HasBuildConfig env, HasGHCVariant env)
=> CompilerBuild
-> m Text
-> RIO env Text
getGhcKey ghcBuild = do
ghcVariant <- view ghcVariantL
platform <- view platformL
osKey <- getOSKey platform
pure $
osKey
<> T.pack (ghcVariantSuffix ghcVariant)
<> T.pack (compilerBuildSuffix ghcBuild)
wantedComiler <- view $ buildConfigL.to (smwCompiler . bcSMWanted)
ghcVersion <- case wantedComiler of
WCGhc version -> pure version
WCGhcjs _ _ -> throwIO GhcjsNotSupported
WCGhcGit _ _ -> throwIO DownloadAndInstallCompilerError
let variantSuffix = ghcVariantSuffix ghcVariant
buildSuffix = compilerBuildSuffix ghcBuild
ghcDir <- parseRelDir $
"ghc"
<> variantSuffix
<> buildSuffix
<> "-"
<> versionString ghcVersion
osKey <- getOSKey "GHC" ghcDir
pure $ osKey <> T.pack variantSuffix <> T.pack buildSuffix

getOSKey ::
(MonadThrow m)
=> Platform
-> m Text
getOSKey platform =
(HasConfig env, HasPlatform env)
=> StyleDoc
-- ^ Description of the tool that is being set up.
-> Path Rel Dir
-- ^ Root directory of tool.
-> RIO env Text
getOSKey tool toolDir = do
programsDir <- view $ configL.to configLocalPrograms
platform <- view platformL
case platform of
Platform I386 Cabal.Linux -> pure "linux32"
Platform X86_64 Cabal.Linux -> pure "linux64"
Expand All @@ -2098,7 +2131,8 @@ getOSKey platform =
Platform Sparc Cabal.Linux -> pure "linux-sparc"
Platform AArch64 Cabal.OSX -> pure "macosx-aarch64"
Platform AArch64 Cabal.FreeBSD -> pure "freebsd-aarch64"
Platform arch os -> prettyThrowM $ UnsupportedSetupCombo os arch
Platform arch os ->
prettyThrowM $ UnsupportedSetupCombo os arch tool toolDir programsDir

downloadOrUseLocal ::
(HasTerm env, HasBuildConfig env)
Expand Down

0 comments on commit 332f35a

Please sign in to comment.