{-# LANGUAGE FlexibleContexts #-}
{-# LANGUAGE RankNTypes #-}
module Distribution.Simple.GHC.Internal (
configureToolchain,
getLanguages,
getExtensions,
targetPlatform,
getGhcInfo,
componentCcGhcOptions,
componentCmmGhcOptions,
componentCxxGhcOptions,
componentAsmGhcOptions,
componentJsGhcOptions,
componentGhcOptions,
mkGHCiLibName,
mkGHCiProfLibName,
filterGhciFlags,
ghcLookupProperty,
getHaskellObjects,
mkGhcOptPackages,
substTopDir,
checkPackageDbEnvVar,
profDetailLevelFlag,
ghcArchString,
ghcOsString,
ghcPlatformAndVersionString,
GhcEnvironmentFileEntry(..),
writeGhcEnvironmentFile,
simpleGhcEnvironmentFile,
ghcEnvironmentFileName,
renderGhcEnvironmentFile,
renderGhcEnvironmentFileEntry,
) where
import Prelude ()
import Distribution.Compat.Prelude
import Distribution.Simple.GHC.ImplInfo
import Distribution.Types.ComponentLocalBuildInfo
import Distribution.Backpack
import qualified Distribution.InstalledPackageInfo as IPI
import Distribution.PackageDescription
import Distribution.Lex
import Distribution.Simple.Compiler
import Distribution.Simple.Program.GHC
import Distribution.Simple.Setup
import qualified Distribution.ModuleName as ModuleName
import Distribution.Simple.Program
import Distribution.Simple.LocalBuildInfo
import Distribution.Types.UnitId
import Distribution.Types.LocalBuildInfo
import Distribution.Types.TargetInfo
import Distribution.Simple.Utils
import Distribution.Simple.BuildPaths
import Distribution.System
import Distribution.Pretty ( prettyShow )
import Distribution.Parsec ( simpleParsec )
import Distribution.Utils.NubList ( toNubListR )
import Distribution.Verbosity
import Distribution.Compat.Stack
import Distribution.Version (Version)
import Distribution.Utils.Path
import Language.Haskell.Extension
import qualified Data.Map as Map
import qualified Data.ByteString.Lazy.Char8 as BS
import System.Directory ( getDirectoryContents, getTemporaryDirectory )
import System.Environment ( getEnv )
import System.FilePath ( (</>), (<.>), takeExtension
, takeDirectory, takeFileName)
import System.IO ( hClose, hPutStrLn )
targetPlatform :: [(String, String)] -> Maybe Platform
targetPlatform :: [(String, String)] -> Maybe Platform
targetPlatform [(String, String)]
ghcInfo = String -> Maybe Platform
platformFromTriple forall (m :: * -> *) a b. Monad m => (a -> m b) -> m a -> m b
=<< forall a b. Eq a => a -> [(a, b)] -> Maybe b
lookup String
"Target platform" [(String, String)]
ghcInfo
configureToolchain :: GhcImplInfo
-> ConfiguredProgram
-> Map String String
-> ProgramDb
-> ProgramDb
configureToolchain :: GhcImplInfo
-> ConfiguredProgram -> Map String String -> ProgramDb -> ProgramDb
configureToolchain GhcImplInfo
_implInfo ConfiguredProgram
ghcProg Map String String
ghcInfo =
Program -> ProgramDb -> ProgramDb
addKnownProgram Program
gccProgram {
programFindLocation :: Verbosity -> ProgramSearchPath -> IO (Maybe (String, [String]))
programFindLocation = String
-> [String]
-> Verbosity
-> ProgramSearchPath
-> IO (Maybe (String, [String]))
findProg String
gccProgramName [String]
extraGccPath,
programPostConf :: Verbosity -> ConfiguredProgram -> IO ConfiguredProgram
programPostConf = Verbosity -> ConfiguredProgram -> IO ConfiguredProgram
configureGcc
}
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Program -> ProgramDb -> ProgramDb
addKnownProgram Program
ldProgram {
programFindLocation :: Verbosity -> ProgramSearchPath -> IO (Maybe (String, [String]))
programFindLocation = String
-> [String]
-> Verbosity
-> ProgramSearchPath
-> IO (Maybe (String, [String]))
findProg String
ldProgramName [String]
extraLdPath,
programPostConf :: Verbosity -> ConfiguredProgram -> IO ConfiguredProgram
programPostConf = Verbosity -> ConfiguredProgram -> IO ConfiguredProgram
configureLd
}
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Program -> ProgramDb -> ProgramDb
addKnownProgram Program
arProgram {
programFindLocation :: Verbosity -> ProgramSearchPath -> IO (Maybe (String, [String]))
programFindLocation = String
-> [String]
-> Verbosity
-> ProgramSearchPath
-> IO (Maybe (String, [String]))
findProg String
arProgramName [String]
extraArPath
}
forall b c a. (b -> c) -> (a -> b) -> a -> c
. Program -> ProgramDb -> ProgramDb
addKnownProgram Program
stripProgram {
programFindLocation :: Verbosity -> ProgramSearchPath -> IO (Maybe (String, [String]))
programFindLocation = String
-> [String]
-> Verbosity
-> ProgramSearchPath
-> IO (Maybe (String, [String]))
findProg String
stripProgramName [String]
extraStripPath
}
where
compilerDir :: String
compilerDir = String -> String
takeDirectory (ConfiguredProgram -> String
programPath ConfiguredProgram
ghcProg)
base_dir :: String
base_dir = String -> String
takeDirectory String
compilerDir
mingwBinDir :: String
mingwBinDir = String
base_dir String -> String -> String
</> String
"mingw" String -> String -> String
</> String
"bin"
isWindows :: Bool
isWindows = case OS
buildOS of OS
Windows -> Bool
True; OS
_ -> Bool
False
binPrefix :: String
binPrefix = String
""
maybeName :: Program -> Maybe FilePath -> String
maybeName :: Program -> Maybe String -> String
maybeName Program
prog = forall b a. b -> (a -> b) -> Maybe a -> b
maybe (Program -> String
programName Program
prog) (String -> String
dropExeExtension forall b c a. (b -> c) -> (a -> b) -> a -> c
. String -> String
takeFileName)
gccProgramName :: String
gccProgramName = Program -> Maybe String -> String
maybeName Program
gccProgram Maybe String
mbGccLocation
ldProgramName :: String
ldProgramName = Program -> Maybe String -> String
maybeName Program
ldProgram Maybe String
mbLdLocation
arProgramName :: String
arProgramName = Program -> Maybe String -> String
maybeName Program
arProgram Maybe String
mbArLocation
stripProgramName :: String
stripProgramName = Program -> Maybe String -> String
maybeName Program
stripProgram Maybe String
mbStripLocation
mkExtraPath :: Maybe FilePath -> FilePath -> [FilePath]
mkExtraPath :: Maybe String -> String -> [String]
mkExtraPath Maybe String
mbPath String
mingwPath | Bool
isWindows = [String]
mbDir forall a. [a] -> [a] -> [a]
++ [String
mingwPath]
| Bool
otherwise = [String]
mbDir
where
mbDir :: [String]
mbDir = forall a. Maybe a -> [a]
maybeToList forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
fmap String -> String
takeDirectory forall a b. (a -> b) -> a -> b
$ Maybe String
mbPath
extraGccPath :: [String]
extraGccPath = Maybe String -> String -> [String]
mkExtraPath Maybe String
mbGccLocation String
windowsExtraGccDir
extraLdPath :: [String]
extraLdPath = Maybe String -> String -> [String]
mkExtraPath Maybe String
mbLdLocation String
windowsExtraLdDir
extraArPath :: [String]
extraArPath = Maybe String -> String -> [String]
mkExtraPath Maybe String
mbArLocation String
windowsExtraArDir
extraStripPath :: [String]
extraStripPath = Maybe String -> String -> [String]
mkExtraPath Maybe String
mbStripLocation String
windowsExtraStripDir
(String
windowsExtraGccDir, String
windowsExtraLdDir,
String
windowsExtraArDir, String
windowsExtraStripDir) =
let b :: String
b = String
mingwBinDir String -> String -> String
</> String
binPrefix
in (String
b, String
b, String
b, String
b)
findProg :: String -> [FilePath]
-> Verbosity -> ProgramSearchPath
-> IO (Maybe (FilePath, [FilePath]))
findProg :: String
-> [String]
-> Verbosity
-> ProgramSearchPath
-> IO (Maybe (String, [String]))
findProg String
progName [String]
extraPath Verbosity
v ProgramSearchPath
searchpath =
Verbosity
-> ProgramSearchPath -> String -> IO (Maybe (String, [String]))
findProgramOnSearchPath Verbosity
v ProgramSearchPath
searchpath' String
progName
where
searchpath' :: ProgramSearchPath
searchpath' = (forall a b. (a -> b) -> [a] -> [b]
map String -> ProgramSearchPathEntry
ProgramSearchPathDir [String]
extraPath) forall a. [a] -> [a] -> [a]
++ ProgramSearchPath
searchpath
mbGccLocation :: Maybe String
mbGccLocation = forall k a. Ord k => k -> Map k a -> Maybe a
Map.lookup String
"C compiler command" Map String String
ghcInfo
mbLdLocation :: Maybe String
mbLdLocation = forall k a. Ord k => k -> Map k a -> Maybe a
Map.lookup String
"ld command" Map String String
ghcInfo
mbArLocation :: Maybe String
mbArLocation = forall k a. Ord k => k -> Map k a -> Maybe a
Map.lookup String
"ar command" Map String String
ghcInfo
mbStripLocation :: Maybe String
mbStripLocation = forall k a. Ord k => k -> Map k a -> Maybe a
Map.lookup String
"strip command" Map String String
ghcInfo
ccFlags :: [String]
ccFlags = String -> [String]
getFlags String
"C compiler flags"
gccLinkerFlags :: [String]
gccLinkerFlags = String -> [String]
getFlags String
"Gcc Linker flags" forall a. [a] -> [a] -> [a]
++ String -> [String]
getFlags String
"C compiler link flags"
ldLinkerFlags :: [String]
ldLinkerFlags = String -> [String]
getFlags String
"Ld Linker flags" forall a. [a] -> [a] -> [a]
++ String -> [String]
getFlags String
"ld flags"
getFlags :: String -> [String]
getFlags :: String -> [String]
getFlags String
key =
case forall k a. Ord k => k -> Map k a -> Maybe a
Map.lookup String
key Map String String
ghcInfo of
Maybe String
Nothing -> []
Just String
flags
| ([String]
flags', String
""):[([String], String)]
_ <- forall a. Read a => ReadS a
reads String
flags -> [String]
flags'
| Bool
otherwise -> String -> [String]
tokenizeQuotedWords String
flags
configureGcc :: Verbosity -> ConfiguredProgram -> IO ConfiguredProgram
configureGcc :: Verbosity -> ConfiguredProgram -> IO ConfiguredProgram
configureGcc Verbosity
_v ConfiguredProgram
gccProg = do
forall (m :: * -> *) a. Monad m => a -> m a
return ConfiguredProgram
gccProg {
programDefaultArgs :: [String]
programDefaultArgs = ConfiguredProgram -> [String]
programDefaultArgs ConfiguredProgram
gccProg
forall a. [a] -> [a] -> [a]
++ [String]
ccFlags forall a. [a] -> [a] -> [a]
++ [String]
gccLinkerFlags
}
configureLd :: Verbosity -> ConfiguredProgram -> IO ConfiguredProgram
configureLd :: Verbosity -> ConfiguredProgram -> IO ConfiguredProgram
configureLd Verbosity
v ConfiguredProgram
ldProg = do
ConfiguredProgram
ldProg' <- Verbosity -> ConfiguredProgram -> IO ConfiguredProgram
configureLd' Verbosity
v ConfiguredProgram
ldProg
forall (m :: * -> *) a. Monad m => a -> m a
return ConfiguredProgram
ldProg' {
programDefaultArgs :: [String]
programDefaultArgs = ConfiguredProgram -> [String]
programDefaultArgs ConfiguredProgram
ldProg' forall a. [a] -> [a] -> [a]
++ [String]
ldLinkerFlags
}
configureLd' :: Verbosity -> ConfiguredProgram -> IO ConfiguredProgram
configureLd' :: Verbosity -> ConfiguredProgram -> IO ConfiguredProgram
configureLd' Verbosity
verbosity ConfiguredProgram
ldProg = do
String
tempDir <- IO String
getTemporaryDirectory
Bool
ldx <- forall a. String -> String -> (String -> Handle -> IO a) -> IO a
withTempFile String
tempDir String
".c" forall a b. (a -> b) -> a -> b
$ \String
testcfile Handle
testchnd ->
forall a. String -> String -> (String -> Handle -> IO a) -> IO a
withTempFile String
tempDir String
".o" forall a b. (a -> b) -> a -> b
$ \String
testofile Handle
testohnd -> do
Handle -> String -> IO ()
hPutStrLn Handle
testchnd String
"int foo() { return 0; }"
Handle -> IO ()
hClose Handle
testchnd; Handle -> IO ()
hClose Handle
testohnd
Verbosity -> ConfiguredProgram -> [String] -> IO ()
runProgram Verbosity
verbosity ConfiguredProgram
ghcProg
[ String
"-hide-all-packages"
, String
"-c", String
testcfile
, String
"-o", String
testofile
]
forall a. String -> String -> (String -> Handle -> IO a) -> IO a
withTempFile String
tempDir String
".o" forall a b. (a -> b) -> a -> b
$ \String
testofile' Handle
testohnd' ->
do
Handle -> IO ()
hClose Handle
testohnd'
String
_ <- Verbosity -> ConfiguredProgram -> [String] -> IO String
getProgramOutput Verbosity
verbosity ConfiguredProgram
ldProg
[String
"-x", String
"-r", String
testofile, String
"-o", String
testofile']
forall (m :: * -> *) a. Monad m => a -> m a
return Bool
True
forall a. IO a -> (IOException -> IO a) -> IO a
`catchIO` (\IOException
_ -> forall (m :: * -> *) a. Monad m => a -> m a
return Bool
False)
forall a. IO a -> (ExitCode -> IO a) -> IO a
`catchExit` (\ExitCode
_ -> forall (m :: * -> *) a. Monad m => a -> m a
return Bool
False)
if Bool
ldx
then forall (m :: * -> *) a. Monad m => a -> m a
return ConfiguredProgram
ldProg { programDefaultArgs :: [String]
programDefaultArgs = [String
"-x"] }
else forall (m :: * -> *) a. Monad m => a -> m a
return ConfiguredProgram
ldProg
getLanguages :: Verbosity -> GhcImplInfo -> ConfiguredProgram
-> IO [(Language, String)]
getLanguages :: Verbosity
-> GhcImplInfo -> ConfiguredProgram -> IO [(Language, String)]
getLanguages Verbosity
_ GhcImplInfo
implInfo ConfiguredProgram
_
| GhcImplInfo -> Bool
supportsGHC2021 GhcImplInfo
implInfo = forall (m :: * -> *) a. Monad m => a -> m a
return
[ (Language
GHC2021, String
"-XGHC2021")
, (Language
Haskell2010, String
"-XHaskell2010")
, (Language
Haskell98, String
"-XHaskell98")
]
| GhcImplInfo -> Bool
supportsHaskell2010 GhcImplInfo
implInfo = forall (m :: * -> *) a. Monad m => a -> m a
return [(Language
Haskell98, String
"-XHaskell98")
,(Language
Haskell2010, String
"-XHaskell2010")]
| Bool
otherwise = forall (m :: * -> *) a. Monad m => a -> m a
return [(Language
Haskell98, String
"")]
getGhcInfo :: Verbosity -> GhcImplInfo -> ConfiguredProgram
-> IO [(String, String)]
getGhcInfo :: Verbosity
-> GhcImplInfo -> ConfiguredProgram -> IO [(String, String)]
getGhcInfo Verbosity
verbosity GhcImplInfo
_implInfo ConfiguredProgram
ghcProg = do
String
xs <- Verbosity -> ConfiguredProgram -> [String] -> IO String
getProgramOutput Verbosity
verbosity (ConfiguredProgram -> ConfiguredProgram
suppressOverrideArgs ConfiguredProgram
ghcProg)
[String
"--info"]
case forall a. Read a => ReadS a
reads String
xs of
[([(String, String)]
i, String
ss)]
| forall (t :: * -> *) a. Foldable t => (a -> Bool) -> t a -> Bool
all Char -> Bool
isSpace String
ss ->
forall (m :: * -> *) a. Monad m => a -> m a
return [(String, String)]
i
[([(String, String)], String)]
_ ->
forall a. Verbosity -> String -> IO a
die' Verbosity
verbosity String
"Can't parse --info output of GHC"
getExtensions :: Verbosity -> GhcImplInfo -> ConfiguredProgram
-> IO [(Extension, Maybe String)]
getExtensions :: Verbosity
-> GhcImplInfo
-> ConfiguredProgram
-> IO [(Extension, Maybe String)]
getExtensions Verbosity
verbosity GhcImplInfo
implInfo ConfiguredProgram
ghcProg = do
String
str <- Verbosity -> ConfiguredProgram -> [String] -> IO String
getProgramOutput Verbosity
verbosity (ConfiguredProgram -> ConfiguredProgram
suppressOverrideArgs ConfiguredProgram
ghcProg)
[String
"--supported-languages"]
let extStrs :: [String]
extStrs = if GhcImplInfo -> Bool
reportsNoExt GhcImplInfo
implInfo
then String -> [String]
lines String
str
else
[ String
extStr''
| String
extStr <- String -> [String]
lines String
str
, let extStr' :: String
extStr' = case String
extStr of
Char
'N' : Char
'o' : String
xs -> String
xs
String
_ -> String
"No" forall a. [a] -> [a] -> [a]
++ String
extStr
, String
extStr'' <- [String
extStr, String
extStr']
]
let extensions0 :: [(Extension, Maybe String)]
extensions0 = [ (Extension
ext, forall a. a -> Maybe a
Just forall a b. (a -> b) -> a -> b
$ String
"-X" forall a. [a] -> [a] -> [a]
++ forall a. Pretty a => a -> String
prettyShow Extension
ext)
| Just Extension
ext <- forall a b. (a -> b) -> [a] -> [b]
map forall a. Parsec a => String -> Maybe a
simpleParsec [String]
extStrs ]
extensions1 :: [(Extension, Maybe String)]
extensions1 = if GhcImplInfo -> Bool
alwaysNondecIndent GhcImplInfo
implInfo
then
(KnownExtension -> Extension
EnableExtension KnownExtension
NondecreasingIndentation, forall a. Maybe a
Nothing) forall a. a -> [a] -> [a]
:
[(Extension, Maybe String)]
extensions0
else [(Extension, Maybe String)]
extensions0
forall (m :: * -> *) a. Monad m => a -> m a
return [(Extension, Maybe String)]
extensions1
componentCcGhcOptions :: Verbosity -> GhcImplInfo -> LocalBuildInfo
-> BuildInfo -> ComponentLocalBuildInfo
-> FilePath -> FilePath
-> GhcOptions
componentCcGhcOptions :: Verbosity
-> GhcImplInfo
-> LocalBuildInfo
-> BuildInfo
-> ComponentLocalBuildInfo
-> String
-> String
-> GhcOptions
componentCcGhcOptions Verbosity
verbosity GhcImplInfo
_implInfo LocalBuildInfo
lbi BuildInfo
bi ComponentLocalBuildInfo
clbi String
odir String
filename =
forall a. Monoid a => a
mempty {
ghcOptVerbosity :: Flag Verbosity
ghcOptVerbosity = forall a. a -> Flag a
toFlag (forall a. Ord a => a -> a -> a
min Verbosity
verbosity Verbosity
normal),
ghcOptMode :: Flag GhcMode
ghcOptMode = forall a. a -> Flag a
toFlag GhcMode
GhcModeCompile,
ghcOptInputFiles :: NubListR String
ghcOptInputFiles = forall a. Ord a => [a] -> NubListR a
toNubListR [String
filename],
ghcOptCppIncludePath :: NubListR String
ghcOptCppIncludePath = forall a. Ord a => [a] -> NubListR a
toNubListR forall a b. (a -> b) -> a -> b
$ [LocalBuildInfo -> ComponentLocalBuildInfo -> String
autogenComponentModulesDir LocalBuildInfo
lbi ComponentLocalBuildInfo
clbi
,LocalBuildInfo -> String
autogenPackageModulesDir LocalBuildInfo
lbi
,String
odir]
forall a. [a] -> [a] -> [a]
++ BuildInfo -> [String]
includeDirs BuildInfo
bi
forall a. [a] -> [a] -> [a]
++ [LocalBuildInfo -> String
buildDir LocalBuildInfo
lbi String -> String -> String
</> String
dir | String
dir <- BuildInfo -> [String]
includeDirs BuildInfo
bi],
ghcOptHideAllPackages :: Flag Bool
ghcOptHideAllPackages= forall a. a -> Flag a
toFlag Bool
True,
ghcOptPackageDBs :: PackageDBStack
ghcOptPackageDBs = LocalBuildInfo -> PackageDBStack
withPackageDB LocalBuildInfo
lbi,
ghcOptPackages :: NubListR (OpenUnitId, ModuleRenaming)
ghcOptPackages = forall a. Ord a => [a] -> NubListR a
toNubListR forall a b. (a -> b) -> a -> b
$ ComponentLocalBuildInfo -> [(OpenUnitId, ModuleRenaming)]
mkGhcOptPackages ComponentLocalBuildInfo
clbi,
ghcOptCcOptions :: [String]
ghcOptCcOptions = (case LocalBuildInfo -> OptimisationLevel
withOptimization LocalBuildInfo
lbi of
OptimisationLevel
NoOptimisation -> []
OptimisationLevel
_ -> [String
"-O2"]) forall a. [a] -> [a] -> [a]
++
(case LocalBuildInfo -> DebugInfoLevel
withDebugInfo LocalBuildInfo
lbi of
DebugInfoLevel
NoDebugInfo -> []
DebugInfoLevel
MinimalDebugInfo -> [String
"-g1"]
DebugInfoLevel
NormalDebugInfo -> [String
"-g"]
DebugInfoLevel
MaximalDebugInfo -> [String
"-g3"]) forall a. [a] -> [a] -> [a]
++
BuildInfo -> [String]
ccOptions BuildInfo
bi,
ghcOptCcProgram :: Flag String
ghcOptCcProgram = forall a. Maybe a -> Flag a
maybeToFlag forall a b. (a -> b) -> a -> b
$ ConfiguredProgram -> String
programPath forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$>
Program -> ProgramDb -> Maybe ConfiguredProgram
lookupProgram Program
gccProgram (LocalBuildInfo -> ProgramDb
withPrograms LocalBuildInfo
lbi),
ghcOptObjDir :: Flag String
ghcOptObjDir = forall a. a -> Flag a
toFlag String
odir,
ghcOptExtra :: [String]
ghcOptExtra = CompilerFlavor -> BuildInfo -> [String]
hcOptions CompilerFlavor
GHC BuildInfo
bi
}
componentCxxGhcOptions :: Verbosity -> GhcImplInfo -> LocalBuildInfo
-> BuildInfo -> ComponentLocalBuildInfo
-> FilePath -> FilePath
-> GhcOptions
componentCxxGhcOptions :: Verbosity
-> GhcImplInfo
-> LocalBuildInfo
-> BuildInfo
-> ComponentLocalBuildInfo
-> String
-> String
-> GhcOptions
componentCxxGhcOptions Verbosity
verbosity GhcImplInfo
_implInfo LocalBuildInfo
lbi BuildInfo
bi ComponentLocalBuildInfo
clbi String
odir String
filename =
forall a. Monoid a => a
mempty {
ghcOptVerbosity :: Flag Verbosity
ghcOptVerbosity = forall a. a -> Flag a
toFlag (forall a. Ord a => a -> a -> a
min Verbosity
verbosity Verbosity
normal),
ghcOptMode :: Flag GhcMode
ghcOptMode = forall a. a -> Flag a
toFlag GhcMode
GhcModeCompile,
ghcOptInputFiles :: NubListR String
ghcOptInputFiles = forall a. Ord a => [a] -> NubListR a
toNubListR [String
filename],
ghcOptCppIncludePath :: NubListR String
ghcOptCppIncludePath = forall a. Ord a => [a] -> NubListR a
toNubListR forall a b. (a -> b) -> a -> b
$ [LocalBuildInfo -> ComponentLocalBuildInfo -> String
autogenComponentModulesDir LocalBuildInfo
lbi ComponentLocalBuildInfo
clbi
,LocalBuildInfo -> String
autogenPackageModulesDir LocalBuildInfo
lbi
,String
odir]
forall a. [a] -> [a] -> [a]
++ BuildInfo -> [String]
includeDirs BuildInfo
bi
forall a. [a] -> [a] -> [a]
++ [LocalBuildInfo -> String
buildDir LocalBuildInfo
lbi String -> String -> String
</> String
dir | String
dir <- BuildInfo -> [String]
includeDirs BuildInfo
bi],
ghcOptHideAllPackages :: Flag Bool
ghcOptHideAllPackages= forall a. a -> Flag a
toFlag Bool
True,
ghcOptPackageDBs :: PackageDBStack
ghcOptPackageDBs = LocalBuildInfo -> PackageDBStack
withPackageDB LocalBuildInfo
lbi,
ghcOptPackages :: NubListR (OpenUnitId, ModuleRenaming)
ghcOptPackages = forall a. Ord a => [a] -> NubListR a
toNubListR forall a b. (a -> b) -> a -> b
$ ComponentLocalBuildInfo -> [(OpenUnitId, ModuleRenaming)]
mkGhcOptPackages ComponentLocalBuildInfo
clbi,
ghcOptCxxOptions :: [String]
ghcOptCxxOptions = (case LocalBuildInfo -> OptimisationLevel
withOptimization LocalBuildInfo
lbi of
OptimisationLevel
NoOptimisation -> []
OptimisationLevel
_ -> [String
"-O2"]) forall a. [a] -> [a] -> [a]
++
(case LocalBuildInfo -> DebugInfoLevel
withDebugInfo LocalBuildInfo
lbi of
DebugInfoLevel
NoDebugInfo -> []
DebugInfoLevel
MinimalDebugInfo -> [String
"-g1"]
DebugInfoLevel
NormalDebugInfo -> [String
"-g"]
DebugInfoLevel
MaximalDebugInfo -> [String
"-g3"]) forall a. [a] -> [a] -> [a]
++
BuildInfo -> [String]
cxxOptions BuildInfo
bi,
ghcOptCcProgram :: Flag String
ghcOptCcProgram = forall a. Maybe a -> Flag a
maybeToFlag forall a b. (a -> b) -> a -> b
$ ConfiguredProgram -> String
programPath forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
<$>
Program -> ProgramDb -> Maybe ConfiguredProgram
lookupProgram Program
gccProgram (LocalBuildInfo -> ProgramDb
withPrograms LocalBuildInfo
lbi),
ghcOptObjDir :: Flag String
ghcOptObjDir = forall a. a -> Flag a
toFlag String
odir,
ghcOptExtra :: [String]
ghcOptExtra = CompilerFlavor -> BuildInfo -> [String]
hcOptions CompilerFlavor
GHC BuildInfo
bi
}
componentAsmGhcOptions :: Verbosity -> GhcImplInfo -> LocalBuildInfo
-> BuildInfo -> ComponentLocalBuildInfo
-> FilePath -> FilePath
-> GhcOptions
componentAsmGhcOptions :: Verbosity
-> GhcImplInfo
-> LocalBuildInfo
-> BuildInfo
-> ComponentLocalBuildInfo
-> String
-> String
-> GhcOptions
componentAsmGhcOptions Verbosity
verbosity GhcImplInfo
_implInfo LocalBuildInfo
lbi BuildInfo
bi ComponentLocalBuildInfo
clbi String
odir String
filename =
forall a. Monoid a => a
mempty {
ghcOptVerbosity :: Flag Verbosity
ghcOptVerbosity = forall a. a -> Flag a
toFlag (forall a. Ord a => a -> a -> a
min Verbosity
verbosity Verbosity
normal),
ghcOptMode :: Flag GhcMode
ghcOptMode = forall a. a -> Flag a
toFlag GhcMode
GhcModeCompile,
ghcOptInputFiles :: NubListR String
ghcOptInputFiles = forall a. Ord a => [a] -> NubListR a
toNubListR [String
filename],
ghcOptCppIncludePath :: NubListR String
ghcOptCppIncludePath = forall a. Ord a => [a] -> NubListR a
toNubListR forall a b. (a -> b) -> a -> b
$ [LocalBuildInfo -> ComponentLocalBuildInfo -> String
autogenComponentModulesDir LocalBuildInfo
lbi ComponentLocalBuildInfo
clbi
,LocalBuildInfo -> String
autogenPackageModulesDir LocalBuildInfo
lbi
,String
odir]
forall a. [a] -> [a] -> [a]
++ BuildInfo -> [String]
includeDirs BuildInfo
bi
forall a. [a] -> [a] -> [a]
++ [LocalBuildInfo -> String
buildDir LocalBuildInfo
lbi String -> String -> String
</> String
dir | String
dir <- BuildInfo -> [String]
includeDirs BuildInfo
bi],
ghcOptHideAllPackages :: Flag Bool
ghcOptHideAllPackages= forall a. a -> Flag a
toFlag Bool
True,
ghcOptPackageDBs :: PackageDBStack
ghcOptPackageDBs = LocalBuildInfo -> PackageDBStack
withPackageDB LocalBuildInfo
lbi,
ghcOptPackages :: NubListR (OpenUnitId, ModuleRenaming)
ghcOptPackages = forall a. Ord a => [a] -> NubListR a
toNubListR forall a b. (a -> b) -> a -> b
$ ComponentLocalBuildInfo -> [(OpenUnitId, ModuleRenaming)]
mkGhcOptPackages ComponentLocalBuildInfo
clbi,
ghcOptAsmOptions :: [String]
ghcOptAsmOptions = (case LocalBuildInfo -> OptimisationLevel
withOptimization LocalBuildInfo
lbi of
OptimisationLevel
NoOptimisation -> []
OptimisationLevel
_ -> [String
"-O2"]) forall a. [a] -> [a] -> [a]
++
(case LocalBuildInfo -> DebugInfoLevel
withDebugInfo LocalBuildInfo
lbi of
DebugInfoLevel
NoDebugInfo -> []
DebugInfoLevel
MinimalDebugInfo -> [String
"-g1"]
DebugInfoLevel
NormalDebugInfo -> [String
"-g"]
DebugInfoLevel
MaximalDebugInfo -> [String
"-g3"]) forall a. [a] -> [a] -> [a]
++
BuildInfo -> [String]
asmOptions BuildInfo
bi,
ghcOptObjDir :: Flag String
ghcOptObjDir = forall a. a -> Flag a
toFlag String
odir
}
componentJsGhcOptions :: Verbosity -> GhcImplInfo -> LocalBuildInfo
-> BuildInfo -> ComponentLocalBuildInfo
-> FilePath -> FilePath
-> GhcOptions
componentJsGhcOptions :: Verbosity
-> GhcImplInfo
-> LocalBuildInfo
-> BuildInfo
-> ComponentLocalBuildInfo
-> String
-> String
-> GhcOptions
componentJsGhcOptions Verbosity
verbosity GhcImplInfo
_implInfo LocalBuildInfo
lbi BuildInfo
bi ComponentLocalBuildInfo
clbi String
odir String
filename =
forall a. Monoid a => a
mempty {
ghcOptVerbosity :: Flag Verbosity
ghcOptVerbosity = forall a. a -> Flag a
toFlag (forall a. Ord a => a -> a -> a
min Verbosity
verbosity Verbosity
normal),
ghcOptMode :: Flag GhcMode
ghcOptMode = forall a. a -> Flag a
toFlag GhcMode
GhcModeCompile,
ghcOptInputFiles :: NubListR String
ghcOptInputFiles = forall a. Ord a => [a] -> NubListR a
toNubListR [String
filename],
ghcOptCppIncludePath :: NubListR String
ghcOptCppIncludePath = forall a. Ord a => [a] -> NubListR a
toNubListR forall a b. (a -> b) -> a -> b
$ [LocalBuildInfo -> ComponentLocalBuildInfo -> String
autogenComponentModulesDir LocalBuildInfo
lbi ComponentLocalBuildInfo
clbi
,LocalBuildInfo -> String
autogenPackageModulesDir LocalBuildInfo
lbi
,String
odir]
forall a. [a] -> [a] -> [a]
++ BuildInfo -> [String]
includeDirs BuildInfo
bi
forall a. [a] -> [a] -> [a]
++ [LocalBuildInfo -> String
buildDir LocalBuildInfo
lbi String -> String -> String
</> String
dir | String
dir <- BuildInfo -> [String]
includeDirs BuildInfo
bi],
ghcOptHideAllPackages :: Flag Bool
ghcOptHideAllPackages= forall a. a -> Flag a
toFlag Bool
True,
ghcOptPackageDBs :: PackageDBStack
ghcOptPackageDBs = LocalBuildInfo -> PackageDBStack
withPackageDB LocalBuildInfo
lbi,
ghcOptPackages :: NubListR (OpenUnitId, ModuleRenaming)
ghcOptPackages = forall a. Ord a => [a] -> NubListR a
toNubListR forall a b. (a -> b) -> a -> b
$ ComponentLocalBuildInfo -> [(OpenUnitId, ModuleRenaming)]
mkGhcOptPackages ComponentLocalBuildInfo
clbi,
ghcOptObjDir :: Flag String
ghcOptObjDir = forall a. a -> Flag a
toFlag String
odir
}
componentGhcOptions :: Verbosity -> GhcImplInfo -> LocalBuildInfo
-> BuildInfo -> ComponentLocalBuildInfo -> FilePath
-> GhcOptions
componentGhcOptions :: Verbosity
-> GhcImplInfo
-> LocalBuildInfo
-> BuildInfo
-> ComponentLocalBuildInfo
-> String
-> GhcOptions
componentGhcOptions Verbosity
verbosity GhcImplInfo
implInfo LocalBuildInfo
lbi BuildInfo
bi ComponentLocalBuildInfo
clbi String
odir =
forall a. Monoid a => a
mempty {
ghcOptVerbosity :: Flag Verbosity
ghcOptVerbosity = forall a. a -> Flag a
toFlag (forall a. Ord a => a -> a -> a
min Verbosity
verbosity Verbosity
normal),
ghcOptCabal :: Flag Bool
ghcOptCabal = forall a. a -> Flag a
toFlag Bool
True,
ghcOptThisUnitId :: Flag String
ghcOptThisUnitId = case ComponentLocalBuildInfo
clbi of
LibComponentLocalBuildInfo { componentCompatPackageKey :: ComponentLocalBuildInfo -> String
componentCompatPackageKey = String
pk }
-> forall a. a -> Flag a
toFlag String
pk
ComponentLocalBuildInfo
_ -> forall a. Monoid a => a
mempty,
ghcOptThisComponentId :: Flag ComponentId
ghcOptThisComponentId = case ComponentLocalBuildInfo
clbi of
LibComponentLocalBuildInfo { componentComponentId :: ComponentLocalBuildInfo -> ComponentId
componentComponentId = ComponentId
cid
, componentInstantiatedWith :: ComponentLocalBuildInfo -> [(ModuleName, OpenModule)]
componentInstantiatedWith = [(ModuleName, OpenModule)]
insts } ->
if forall (t :: * -> *) a. Foldable t => t a -> Bool
null [(ModuleName, OpenModule)]
insts
then forall a. Monoid a => a
mempty
else forall a. a -> Flag a
toFlag ComponentId
cid
ComponentLocalBuildInfo
_ -> forall a. Monoid a => a
mempty,
ghcOptInstantiatedWith :: [(ModuleName, OpenModule)]
ghcOptInstantiatedWith = case ComponentLocalBuildInfo
clbi of
LibComponentLocalBuildInfo { componentInstantiatedWith :: ComponentLocalBuildInfo -> [(ModuleName, OpenModule)]
componentInstantiatedWith = [(ModuleName, OpenModule)]
insts }
-> [(ModuleName, OpenModule)]
insts
ComponentLocalBuildInfo
_ -> [],
ghcOptNoCode :: Flag Bool
ghcOptNoCode = forall a. a -> Flag a
toFlag forall a b. (a -> b) -> a -> b
$ ComponentLocalBuildInfo -> Bool
componentIsIndefinite ComponentLocalBuildInfo
clbi,
ghcOptHideAllPackages :: Flag Bool
ghcOptHideAllPackages = forall a. a -> Flag a
toFlag Bool
True,
ghcOptWarnMissingHomeModules :: Flag Bool
ghcOptWarnMissingHomeModules = forall a. a -> Flag a
toFlag forall a b. (a -> b) -> a -> b
$ GhcImplInfo -> Bool
flagWarnMissingHomeModules GhcImplInfo
implInfo,
ghcOptPackageDBs :: PackageDBStack
ghcOptPackageDBs = LocalBuildInfo -> PackageDBStack
withPackageDB LocalBuildInfo
lbi,
ghcOptPackages :: NubListR (OpenUnitId, ModuleRenaming)
ghcOptPackages = forall a. Ord a => [a] -> NubListR a
toNubListR forall a b. (a -> b) -> a -> b
$ ComponentLocalBuildInfo -> [(OpenUnitId, ModuleRenaming)]
mkGhcOptPackages ComponentLocalBuildInfo
clbi,
ghcOptSplitSections :: Flag Bool
ghcOptSplitSections = forall a. a -> Flag a
toFlag (LocalBuildInfo -> Bool
splitSections LocalBuildInfo
lbi),
ghcOptSplitObjs :: Flag Bool
ghcOptSplitObjs = forall a. a -> Flag a
toFlag (LocalBuildInfo -> Bool
splitObjs LocalBuildInfo
lbi),
ghcOptSourcePathClear :: Flag Bool
ghcOptSourcePathClear = forall a. a -> Flag a
toFlag Bool
True,
ghcOptSourcePath :: NubListR String
ghcOptSourcePath = forall a. Ord a => [a] -> NubListR a
toNubListR forall a b. (a -> b) -> a -> b
$ [String
odir] forall a. [a] -> [a] -> [a]
++ (forall a b. (a -> b) -> [a] -> [b]
map forall from to. SymbolicPath from to -> String
getSymbolicPath (BuildInfo -> [SymbolicPath PackageDir SourceDir]
hsSourceDirs BuildInfo
bi))
forall a. [a] -> [a] -> [a]
++ [LocalBuildInfo -> ComponentLocalBuildInfo -> String
autogenComponentModulesDir LocalBuildInfo
lbi ComponentLocalBuildInfo
clbi]
forall a. [a] -> [a] -> [a]
++ [LocalBuildInfo -> String
autogenPackageModulesDir LocalBuildInfo
lbi],
ghcOptCppIncludePath :: NubListR String
ghcOptCppIncludePath = forall a. Ord a => [a] -> NubListR a
toNubListR forall a b. (a -> b) -> a -> b
$ [LocalBuildInfo -> ComponentLocalBuildInfo -> String
autogenComponentModulesDir LocalBuildInfo
lbi ComponentLocalBuildInfo
clbi
,LocalBuildInfo -> String
autogenPackageModulesDir LocalBuildInfo
lbi
,String
odir]
forall a. [a] -> [a] -> [a]
++ BuildInfo -> [String]
includeDirs BuildInfo
bi
forall a. [a] -> [a] -> [a]
++ [LocalBuildInfo -> String
buildDir LocalBuildInfo
lbi String -> String -> String
</> String
dir | String
dir <- BuildInfo -> [String]
includeDirs BuildInfo
bi],
ghcOptCppOptions :: [String]
ghcOptCppOptions = BuildInfo -> [String]
cppOptions BuildInfo
bi,
ghcOptCppIncludes :: NubListR String
ghcOptCppIncludes = forall a. Ord a => [a] -> NubListR a
toNubListR forall a b. (a -> b) -> a -> b
$
[LocalBuildInfo -> ComponentLocalBuildInfo -> String
autogenComponentModulesDir LocalBuildInfo
lbi ComponentLocalBuildInfo
clbi String -> String -> String
</> String
cppHeaderName],
ghcOptFfiIncludes :: NubListR String
ghcOptFfiIncludes = forall a. Ord a => [a] -> NubListR a
toNubListR forall a b. (a -> b) -> a -> b
$ BuildInfo -> [String]
includes BuildInfo
bi,
ghcOptObjDir :: Flag String
ghcOptObjDir = forall a. a -> Flag a
toFlag String
odir,
ghcOptHiDir :: Flag String
ghcOptHiDir = forall a. a -> Flag a
toFlag String
odir,
ghcOptStubDir :: Flag String
ghcOptStubDir = forall a. a -> Flag a
toFlag String
odir,
ghcOptOutputDir :: Flag String
ghcOptOutputDir = forall a. a -> Flag a
toFlag String
odir,
ghcOptOptimisation :: Flag GhcOptimisation
ghcOptOptimisation = OptimisationLevel -> Flag GhcOptimisation
toGhcOptimisation (LocalBuildInfo -> OptimisationLevel
withOptimization LocalBuildInfo
lbi),
ghcOptDebugInfo :: Flag DebugInfoLevel
ghcOptDebugInfo = forall a. a -> Flag a
toFlag (LocalBuildInfo -> DebugInfoLevel
withDebugInfo LocalBuildInfo
lbi),
ghcOptExtra :: [String]
ghcOptExtra = CompilerFlavor -> BuildInfo -> [String]
hcOptions CompilerFlavor
GHC BuildInfo
bi,
ghcOptExtraPath :: NubListR String
ghcOptExtraPath = forall a. Ord a => [a] -> NubListR a
toNubListR forall a b. (a -> b) -> a -> b
$ [String]
exe_paths,
ghcOptLanguage :: Flag Language
ghcOptLanguage = forall a. a -> Flag a
toFlag (forall a. a -> Maybe a -> a
fromMaybe Language
Haskell98 (BuildInfo -> Maybe Language
defaultLanguage BuildInfo
bi)),
ghcOptExtensions :: NubListR Extension
ghcOptExtensions = forall a. Ord a => [a] -> NubListR a
toNubListR forall a b. (a -> b) -> a -> b
$ BuildInfo -> [Extension]
usedExtensions BuildInfo
bi,
ghcOptExtensionMap :: Map Extension (Maybe String)
ghcOptExtensionMap = forall k a. Ord k => [(k, a)] -> Map k a
Map.fromList forall b c a. (b -> c) -> (a -> b) -> a -> c
. Compiler -> [(Extension, Maybe String)]
compilerExtensions forall a b. (a -> b) -> a -> b
$ (LocalBuildInfo -> Compiler
compiler LocalBuildInfo
lbi)
}
where
exe_paths :: [String]
exe_paths = [ LocalBuildInfo -> ComponentLocalBuildInfo -> String
componentBuildDir LocalBuildInfo
lbi (TargetInfo -> ComponentLocalBuildInfo
targetCLBI TargetInfo
exe_tgt)
| UnitId
uid <- ComponentLocalBuildInfo -> [UnitId]
componentExeDeps ComponentLocalBuildInfo
clbi
, Just TargetInfo
exe_tgt <- [PackageDescription -> LocalBuildInfo -> UnitId -> Maybe TargetInfo
unitIdTarget' (LocalBuildInfo -> PackageDescription
localPkgDescr LocalBuildInfo
lbi) LocalBuildInfo
lbi UnitId
uid] ]
toGhcOptimisation :: OptimisationLevel -> Flag GhcOptimisation
toGhcOptimisation :: OptimisationLevel -> Flag GhcOptimisation
toGhcOptimisation OptimisationLevel
NoOptimisation = forall a. Monoid a => a
mempty
toGhcOptimisation OptimisationLevel
NormalOptimisation = forall a. a -> Flag a
toFlag GhcOptimisation
GhcNormalOptimisation
toGhcOptimisation OptimisationLevel
MaximumOptimisation = forall a. a -> Flag a
toFlag GhcOptimisation
GhcMaximumOptimisation
componentCmmGhcOptions :: Verbosity -> GhcImplInfo -> LocalBuildInfo
-> BuildInfo -> ComponentLocalBuildInfo
-> FilePath -> FilePath
-> GhcOptions
componentCmmGhcOptions :: Verbosity
-> GhcImplInfo
-> LocalBuildInfo
-> BuildInfo
-> ComponentLocalBuildInfo
-> String
-> String
-> GhcOptions
componentCmmGhcOptions Verbosity
verbosity GhcImplInfo
_implInfo LocalBuildInfo
lbi BuildInfo
bi ComponentLocalBuildInfo
clbi String
odir String
filename =
forall a. Monoid a => a
mempty {
ghcOptVerbosity :: Flag Verbosity
ghcOptVerbosity = forall a. a -> Flag a
toFlag (forall a. Ord a => a -> a -> a
min Verbosity
verbosity Verbosity
normal),
ghcOptMode :: Flag GhcMode
ghcOptMode = forall a. a -> Flag a
toFlag GhcMode
GhcModeCompile,
ghcOptInputFiles :: NubListR String
ghcOptInputFiles = forall a. Ord a => [a] -> NubListR a
toNubListR [String
filename],
ghcOptCppIncludePath :: NubListR String
ghcOptCppIncludePath = forall a. Ord a => [a] -> NubListR a
toNubListR forall a b. (a -> b) -> a -> b
$ [LocalBuildInfo -> ComponentLocalBuildInfo -> String
autogenComponentModulesDir LocalBuildInfo
lbi ComponentLocalBuildInfo
clbi
,LocalBuildInfo -> String
autogenPackageModulesDir LocalBuildInfo
lbi
,String
odir]
forall a. [a] -> [a] -> [a]
++ BuildInfo -> [String]
includeDirs BuildInfo
bi
forall a. [a] -> [a] -> [a]
++ [LocalBuildInfo -> String
buildDir LocalBuildInfo
lbi String -> String -> String
</> String
dir | String
dir <- BuildInfo -> [String]
includeDirs BuildInfo
bi],
ghcOptCppOptions :: [String]
ghcOptCppOptions = BuildInfo -> [String]
cppOptions BuildInfo
bi,
ghcOptCppIncludes :: NubListR String
ghcOptCppIncludes = forall a. Ord a => [a] -> NubListR a
toNubListR forall a b. (a -> b) -> a -> b
$
[LocalBuildInfo -> ComponentLocalBuildInfo -> String
autogenComponentModulesDir LocalBuildInfo
lbi ComponentLocalBuildInfo
clbi String -> String -> String
</> String
cppHeaderName],
ghcOptHideAllPackages :: Flag Bool
ghcOptHideAllPackages= forall a. a -> Flag a
toFlag Bool
True,
ghcOptPackageDBs :: PackageDBStack
ghcOptPackageDBs = LocalBuildInfo -> PackageDBStack
withPackageDB LocalBuildInfo
lbi,
ghcOptPackages :: NubListR (OpenUnitId, ModuleRenaming)
ghcOptPackages = forall a. Ord a => [a] -> NubListR a
toNubListR forall a b. (a -> b) -> a -> b
$ ComponentLocalBuildInfo -> [(OpenUnitId, ModuleRenaming)]
mkGhcOptPackages ComponentLocalBuildInfo
clbi,
ghcOptOptimisation :: Flag GhcOptimisation
ghcOptOptimisation = OptimisationLevel -> Flag GhcOptimisation
toGhcOptimisation (LocalBuildInfo -> OptimisationLevel
withOptimization LocalBuildInfo
lbi),
ghcOptDebugInfo :: Flag DebugInfoLevel
ghcOptDebugInfo = forall a. a -> Flag a
toFlag (LocalBuildInfo -> DebugInfoLevel
withDebugInfo LocalBuildInfo
lbi),
ghcOptExtra :: [String]
ghcOptExtra = BuildInfo -> [String]
cmmOptions BuildInfo
bi,
ghcOptObjDir :: Flag String
ghcOptObjDir = forall a. a -> Flag a
toFlag String
odir
}
filterGhciFlags :: [String] -> [String]
filterGhciFlags :: [String] -> [String]
filterGhciFlags = forall a. (a -> Bool) -> [a] -> [a]
filter String -> Bool
supported
where
supported :: String -> Bool
supported (Char
'-':Char
'O':String
_) = Bool
False
supported String
"-debug" = Bool
False
supported String
"-threaded" = Bool
False
supported String
"-ticky" = Bool
False
supported String
"-eventlog" = Bool
False
supported String
"-prof" = Bool
False
supported String
"-unreg" = Bool
False
supported String
_ = Bool
True
mkGHCiLibName :: UnitId -> String
mkGHCiLibName :: UnitId -> String
mkGHCiLibName UnitId
lib = UnitId -> String
getHSLibraryName UnitId
lib String -> String -> String
<.> String
"o"
mkGHCiProfLibName :: UnitId -> String
mkGHCiProfLibName :: UnitId -> String
mkGHCiProfLibName UnitId
lib = UnitId -> String
getHSLibraryName UnitId
lib String -> String -> String
<.> String
"p_o"
ghcLookupProperty :: String -> Compiler -> Bool
ghcLookupProperty :: String -> Compiler -> Bool
ghcLookupProperty String
prop Compiler
comp =
case forall k a. Ord k => k -> Map k a -> Maybe a
Map.lookup String
prop (Compiler -> Map String String
compilerProperties Compiler
comp) of
Just String
"YES" -> Bool
True
Maybe String
_ -> Bool
False
getHaskellObjects :: GhcImplInfo -> Library -> LocalBuildInfo
-> ComponentLocalBuildInfo
-> FilePath -> String -> Bool -> IO [FilePath]
getHaskellObjects :: GhcImplInfo
-> Library
-> LocalBuildInfo
-> ComponentLocalBuildInfo
-> String
-> String
-> Bool
-> IO [String]
getHaskellObjects GhcImplInfo
_implInfo Library
lib LocalBuildInfo
lbi ComponentLocalBuildInfo
clbi String
pref String
wanted_obj_ext Bool
allow_split_objs
| LocalBuildInfo -> Bool
splitObjs LocalBuildInfo
lbi Bool -> Bool -> Bool
&& Bool
allow_split_objs = do
let splitSuffix :: String
splitSuffix = String
"_" forall a. [a] -> [a] -> [a]
++ String
wanted_obj_ext forall a. [a] -> [a] -> [a]
++ String
"_split"
dirs :: [String]
dirs = [ String
pref String -> String -> String
</> (ModuleName -> String
ModuleName.toFilePath ModuleName
x forall a. [a] -> [a] -> [a]
++ String
splitSuffix)
| ModuleName
x <- Library -> ComponentLocalBuildInfo -> [ModuleName]
allLibModules Library
lib ComponentLocalBuildInfo
clbi ]
[[String]]
objss <- forall (t :: * -> *) (f :: * -> *) a b.
(Traversable t, Applicative f) =>
(a -> f b) -> t a -> f (t b)
traverse String -> IO [String]
getDirectoryContents [String]
dirs
let objs :: [String]
objs = [ String
dir String -> String -> String
</> String
obj
| ([String]
objs',String
dir) <- forall a b. [a] -> [b] -> [(a, b)]
zip [[String]]
objss [String]
dirs, String
obj <- [String]
objs',
let obj_ext :: String
obj_ext = String -> String
takeExtension String
obj,
Char
'.'forall a. a -> [a] -> [a]
:String
wanted_obj_ext forall a. Eq a => a -> a -> Bool
== String
obj_ext ]
forall (m :: * -> *) a. Monad m => a -> m a
return [String]
objs
| Bool
otherwise =
forall (m :: * -> *) a. Monad m => a -> m a
return [ String
pref String -> String -> String
</> ModuleName -> String
ModuleName.toFilePath ModuleName
x String -> String -> String
<.> String
wanted_obj_ext
| ModuleName
x <- Library -> ComponentLocalBuildInfo -> [ModuleName]
allLibModules Library
lib ComponentLocalBuildInfo
clbi ]
mkGhcOptPackages :: ComponentLocalBuildInfo
-> [(OpenUnitId, ModuleRenaming)]
mkGhcOptPackages :: ComponentLocalBuildInfo -> [(OpenUnitId, ModuleRenaming)]
mkGhcOptPackages = ComponentLocalBuildInfo -> [(OpenUnitId, ModuleRenaming)]
componentIncludes
substTopDir :: FilePath -> IPI.InstalledPackageInfo -> IPI.InstalledPackageInfo
substTopDir :: String -> InstalledPackageInfo -> InstalledPackageInfo
substTopDir String
topDir InstalledPackageInfo
ipo
= InstalledPackageInfo
ipo {
importDirs :: [String]
IPI.importDirs = forall a b. (a -> b) -> [a] -> [b]
map String -> String
f (InstalledPackageInfo -> [String]
IPI.importDirs InstalledPackageInfo
ipo),
libraryDirs :: [String]
IPI.libraryDirs = forall a b. (a -> b) -> [a] -> [b]
map String -> String
f (InstalledPackageInfo -> [String]
IPI.libraryDirs InstalledPackageInfo
ipo),
libraryDirsStatic :: [String]
IPI.libraryDirsStatic = forall a b. (a -> b) -> [a] -> [b]
map String -> String
f (InstalledPackageInfo -> [String]
IPI.libraryDirsStatic InstalledPackageInfo
ipo),
includeDirs :: [String]
IPI.includeDirs = forall a b. (a -> b) -> [a] -> [b]
map String -> String
f (InstalledPackageInfo -> [String]
IPI.includeDirs InstalledPackageInfo
ipo),
frameworkDirs :: [String]
IPI.frameworkDirs = forall a b. (a -> b) -> [a] -> [b]
map String -> String
f (InstalledPackageInfo -> [String]
IPI.frameworkDirs InstalledPackageInfo
ipo),
haddockInterfaces :: [String]
IPI.haddockInterfaces = forall a b. (a -> b) -> [a] -> [b]
map String -> String
f (InstalledPackageInfo -> [String]
IPI.haddockInterfaces InstalledPackageInfo
ipo),
haddockHTMLs :: [String]
IPI.haddockHTMLs = forall a b. (a -> b) -> [a] -> [b]
map String -> String
f (InstalledPackageInfo -> [String]
IPI.haddockHTMLs InstalledPackageInfo
ipo)
}
where f :: String -> String
f (Char
'$':Char
't':Char
'o':Char
'p':Char
'd':Char
'i':Char
'r':String
rest) = String
topDir forall a. [a] -> [a] -> [a]
++ String
rest
f String
x = String
x
checkPackageDbEnvVar :: Verbosity -> String -> String -> IO ()
checkPackageDbEnvVar :: Verbosity -> String -> String -> IO ()
checkPackageDbEnvVar Verbosity
verbosity String
compilerName String
packagePathEnvVar = do
Maybe String
mPP <- String -> IO (Maybe String)
lookupEnv String
packagePathEnvVar
forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
when (forall a. Maybe a -> Bool
isJust Maybe String
mPP) forall a b. (a -> b) -> a -> b
$ do
Maybe String
mcsPP <- String -> IO (Maybe String)
lookupEnv String
"CABAL_SANDBOX_PACKAGE_PATH"
forall (f :: * -> *). Applicative f => Bool -> f () -> f ()
unless (Maybe String
mPP forall a. Eq a => a -> a -> Bool
== Maybe String
mcsPP) forall {a}. IO a
abort
where
lookupEnv :: String -> IO (Maybe String)
lookupEnv :: String -> IO (Maybe String)
lookupEnv String
name = (forall a. a -> Maybe a
Just forall (f :: * -> *) a b. Functor f => (a -> b) -> f a -> f b
`fmap` String -> IO String
getEnv String
name)
forall a. IO a -> (IOException -> IO a) -> IO a
`catchIO` forall a b. a -> b -> a
const (forall (m :: * -> *) a. Monad m => a -> m a
return forall a. Maybe a
Nothing)
abort :: IO a
abort =
forall a. Verbosity -> String -> IO a
die' Verbosity
verbosity forall a b. (a -> b) -> a -> b
$ String
"Use of " forall a. [a] -> [a] -> [a]
++ String
compilerName forall a. [a] -> [a] -> [a]
++ String
"'s environment variable "
forall a. [a] -> [a] -> [a]
++ String
packagePathEnvVar forall a. [a] -> [a] -> [a]
++ String
" is incompatible with Cabal. Use the "
forall a. [a] -> [a] -> [a]
++ String
"flag --package-db to specify a package database (it can be "
forall a. [a] -> [a] -> [a]
++ String
"used multiple times)."
CallStack
_ = HasCallStack => CallStack
callStack
profDetailLevelFlag :: Bool -> ProfDetailLevel -> Flag GhcProfAuto
profDetailLevelFlag :: Bool -> ProfDetailLevel -> Flag GhcProfAuto
profDetailLevelFlag Bool
forLib ProfDetailLevel
mpl =
case ProfDetailLevel
mpl of
ProfDetailLevel
ProfDetailNone -> forall a. Monoid a => a
mempty
ProfDetailLevel
ProfDetailDefault | Bool
forLib -> forall a. a -> Flag a
toFlag GhcProfAuto
GhcProfAutoExported
| Bool
otherwise -> forall a. a -> Flag a
toFlag GhcProfAuto
GhcProfAutoToplevel
ProfDetailLevel
ProfDetailExportedFunctions -> forall a. a -> Flag a
toFlag GhcProfAuto
GhcProfAutoExported
ProfDetailLevel
ProfDetailToplevelFunctions -> forall a. a -> Flag a
toFlag GhcProfAuto
GhcProfAutoToplevel
ProfDetailLevel
ProfDetailAllFunctions -> forall a. a -> Flag a
toFlag GhcProfAuto
GhcProfAutoAll
ProfDetailLevel
ProfDetailTopLate -> forall a. a -> Flag a
toFlag GhcProfAuto
GhcProfLate
ProfDetailOther String
_ -> forall a. Monoid a => a
mempty
ghcArchString :: Arch -> String
ghcArchString :: Arch -> String
ghcArchString Arch
PPC = String
"powerpc"
ghcArchString Arch
PPC64 = String
"powerpc64"
ghcArchString Arch
other = forall a. Pretty a => a -> String
prettyShow Arch
other
ghcOsString :: OS -> String
ghcOsString :: OS -> String
ghcOsString OS
Windows = String
"mingw32"
ghcOsString OS
OSX = String
"darwin"
ghcOsString OS
Solaris = String
"solaris2"
ghcOsString OS
other = forall a. Pretty a => a -> String
prettyShow OS
other
ghcPlatformAndVersionString :: Platform -> Version -> String
ghcPlatformAndVersionString :: Platform -> Version -> String
ghcPlatformAndVersionString (Platform Arch
arch OS
os) Version
version =
forall a. [a] -> [[a]] -> [a]
intercalate String
"-" [ Arch -> String
ghcArchString Arch
arch, OS -> String
ghcOsString OS
os, forall a. Pretty a => a -> String
prettyShow Version
version ]
data GhcEnvironmentFileEntry =
String
| GhcEnvFilePackageId UnitId
| GhcEnvFilePackageDb PackageDB
| GhcEnvFileClearPackageDbStack
deriving (GhcEnvironmentFileEntry -> GhcEnvironmentFileEntry -> Bool
forall a. (a -> a -> Bool) -> (a -> a -> Bool) -> Eq a
/= :: GhcEnvironmentFileEntry -> GhcEnvironmentFileEntry -> Bool
$c/= :: GhcEnvironmentFileEntry -> GhcEnvironmentFileEntry -> Bool
== :: GhcEnvironmentFileEntry -> GhcEnvironmentFileEntry -> Bool
$c== :: GhcEnvironmentFileEntry -> GhcEnvironmentFileEntry -> Bool
Eq, Eq GhcEnvironmentFileEntry
GhcEnvironmentFileEntry -> GhcEnvironmentFileEntry -> Bool
GhcEnvironmentFileEntry -> GhcEnvironmentFileEntry -> Ordering
GhcEnvironmentFileEntry
-> GhcEnvironmentFileEntry -> GhcEnvironmentFileEntry
forall a.
Eq a
-> (a -> a -> Ordering)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> Bool)
-> (a -> a -> a)
-> (a -> a -> a)
-> Ord a
min :: GhcEnvironmentFileEntry
-> GhcEnvironmentFileEntry -> GhcEnvironmentFileEntry
$cmin :: GhcEnvironmentFileEntry
-> GhcEnvironmentFileEntry -> GhcEnvironmentFileEntry
max :: GhcEnvironmentFileEntry
-> GhcEnvironmentFileEntry -> GhcEnvironmentFileEntry
$cmax :: GhcEnvironmentFileEntry
-> GhcEnvironmentFileEntry -> GhcEnvironmentFileEntry
>= :: GhcEnvironmentFileEntry -> GhcEnvironmentFileEntry -> Bool
$c>= :: GhcEnvironmentFileEntry -> GhcEnvironmentFileEntry -> Bool
> :: GhcEnvironmentFileEntry -> GhcEnvironmentFileEntry -> Bool
$c> :: GhcEnvironmentFileEntry -> GhcEnvironmentFileEntry -> Bool
<= :: GhcEnvironmentFileEntry -> GhcEnvironmentFileEntry -> Bool
$c<= :: GhcEnvironmentFileEntry -> GhcEnvironmentFileEntry -> Bool
< :: GhcEnvironmentFileEntry -> GhcEnvironmentFileEntry -> Bool
$c< :: GhcEnvironmentFileEntry -> GhcEnvironmentFileEntry -> Bool
compare :: GhcEnvironmentFileEntry -> GhcEnvironmentFileEntry -> Ordering
$ccompare :: GhcEnvironmentFileEntry -> GhcEnvironmentFileEntry -> Ordering
Ord, Int -> GhcEnvironmentFileEntry -> String -> String
[GhcEnvironmentFileEntry] -> String -> String
GhcEnvironmentFileEntry -> String
forall a.
(Int -> a -> String -> String)
-> (a -> String) -> ([a] -> String -> String) -> Show a
showList :: [GhcEnvironmentFileEntry] -> String -> String
$cshowList :: [GhcEnvironmentFileEntry] -> String -> String
show :: GhcEnvironmentFileEntry -> String
$cshow :: GhcEnvironmentFileEntry -> String
showsPrec :: Int -> GhcEnvironmentFileEntry -> String -> String
$cshowsPrec :: Int -> GhcEnvironmentFileEntry -> String -> String
Show)
simpleGhcEnvironmentFile :: PackageDBStack
-> [UnitId]
-> [GhcEnvironmentFileEntry]
simpleGhcEnvironmentFile :: PackageDBStack -> [UnitId] -> [GhcEnvironmentFileEntry]
simpleGhcEnvironmentFile PackageDBStack
packageDBs [UnitId]
pkgids =
GhcEnvironmentFileEntry
GhcEnvFileClearPackageDbStack
forall a. a -> [a] -> [a]
: forall a b. (a -> b) -> [a] -> [b]
map PackageDB -> GhcEnvironmentFileEntry
GhcEnvFilePackageDb PackageDBStack
packageDBs
forall a. [a] -> [a] -> [a]
++ forall a b. (a -> b) -> [a] -> [b]
map UnitId -> GhcEnvironmentFileEntry
GhcEnvFilePackageId [UnitId]
pkgids
writeGhcEnvironmentFile :: FilePath
-> Platform
-> Version
-> [GhcEnvironmentFileEntry]
-> IO FilePath
writeGhcEnvironmentFile :: String
-> Platform -> Version -> [GhcEnvironmentFileEntry] -> IO String
writeGhcEnvironmentFile String
directory Platform
platform Version
ghcversion [GhcEnvironmentFileEntry]
entries = do
String -> ByteString -> IO ()
writeFileAtomic String
envfile forall b c a. (b -> c) -> (a -> b) -> a -> c
. String -> ByteString
BS.pack forall b c a. (b -> c) -> (a -> b) -> a -> c
. [GhcEnvironmentFileEntry] -> String
renderGhcEnvironmentFile forall a b. (a -> b) -> a -> b
$ [GhcEnvironmentFileEntry]
entries
forall (m :: * -> *) a. Monad m => a -> m a
return String
envfile
where
envfile :: String
envfile = String
directory String -> String -> String
</> Platform -> Version -> String
ghcEnvironmentFileName Platform
platform Version
ghcversion
ghcEnvironmentFileName :: Platform -> Version -> FilePath
ghcEnvironmentFileName :: Platform -> Version -> String
ghcEnvironmentFileName Platform
platform Version
ghcversion =
String
".ghc.environment." forall a. [a] -> [a] -> [a]
++ Platform -> Version -> String
ghcPlatformAndVersionString Platform
platform Version
ghcversion
renderGhcEnvironmentFile :: [GhcEnvironmentFileEntry] -> String
renderGhcEnvironmentFile :: [GhcEnvironmentFileEntry] -> String
renderGhcEnvironmentFile =
[String] -> String
unlines forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a b. (a -> b) -> [a] -> [b]
map GhcEnvironmentFileEntry -> String
renderGhcEnvironmentFileEntry
renderGhcEnvironmentFileEntry :: GhcEnvironmentFileEntry -> String
renderGhcEnvironmentFileEntry :: GhcEnvironmentFileEntry -> String
renderGhcEnvironmentFileEntry GhcEnvironmentFileEntry
entry = case GhcEnvironmentFileEntry
entry of
GhcEnvFileComment String
comment -> String -> String
format String
comment
where format :: String -> String
format = forall a. [a] -> [[a]] -> [a]
intercalate String
"\n" forall b c a. (b -> c) -> (a -> b) -> a -> c
. forall a b. (a -> b) -> [a] -> [b]
map (String
"--" String -> String -> String
<++>) forall b c a. (b -> c) -> (a -> b) -> a -> c
. String -> [String]
lines
String
pref <++> :: String -> String -> String
<++> String
"" = String
pref
String
pref <++> String
str = String
pref forall a. [a] -> [a] -> [a]
++ String
" " forall a. [a] -> [a] -> [a]
++ String
str
GhcEnvFilePackageId UnitId
pkgid -> String
"package-id " forall a. [a] -> [a] -> [a]
++ forall a. Pretty a => a -> String
prettyShow UnitId
pkgid
GhcEnvFilePackageDb PackageDB
pkgdb ->
case PackageDB
pkgdb of
PackageDB
GlobalPackageDB -> String
"global-package-db"
PackageDB
UserPackageDB -> String
"user-package-db"
SpecificPackageDB String
dbfile -> String
"package-db " forall a. [a] -> [a] -> [a]
++ String
dbfile
GhcEnvironmentFileEntry
GhcEnvFileClearPackageDbStack -> String
"clear-package-db"