Skip to content

Commit

Permalink
Merge pull request #3281 from commercialhaskell/1297-concrete-monad
Browse files Browse the repository at this point in the history
Use a concrete monad #1297
  • Loading branch information
snoyberg authored Jul 20, 2017
2 parents 74cf3b9 + 5c61387 commit 98c5452
Show file tree
Hide file tree
Showing 43 changed files with 502 additions and 528 deletions.
2 changes: 2 additions & 0 deletions .travis.yml
Original file line number Diff line number Diff line change
Expand Up @@ -73,10 +73,12 @@ before_install:

install:
- echo "$(ghc --version) [$(ghc --print-project-git-commit-id 2> /dev/null || echo '?')]"
# Note: we build store by itself below due to high memory usage
- case "$BUILD" in
style)
stack --system-ghc --no-terminal install hlint;;
stack)
stack --no-terminal build store;
stack --no-terminal test --only-dependencies;;
cabal)
cabal --version;
Expand Down
21 changes: 10 additions & 11 deletions src/Stack/Build.hs
Original file line number Diff line number Diff line change
Expand Up @@ -68,11 +68,11 @@ import System.Win32.Console (setConsoleCP, setConsoleOutputCP, getCons
-- If a buildLock is passed there is an important contract here. That lock must
-- protect the snapshot, and it must be safe to unlock it if there are no further
-- modifications to the snapshot to be performed by this build.
build :: (StackM env m, HasEnvConfig env)
build :: HasEnvConfig env
=> (Set (Path Abs File) -> IO ()) -- ^ callback after discovering all local files
-> Maybe FileLock
-> BuildOptsCLI
-> m ()
-> RIO env ()
build setLocalFiles mbuildLk boptsCli = fixCodePage $ do
bopts <- view buildOptsL
let profiling = boptsLibProfile bopts || boptsExeProfile bopts
Expand Down Expand Up @@ -147,7 +147,7 @@ justLocals =
Map.elems .
planTasks

checkCabalVersion :: (StackM env m, HasEnvConfig env) => m ()
checkCabalVersion :: HasEnvConfig env => RIO env ()
checkCabalVersion = do
allowNewer <- view $ configL.to configAllowNewer
cabalVer <- view cabalVersionL
Expand Down Expand Up @@ -272,9 +272,9 @@ mkBaseConfigOpts boptsCli = do
}

-- | Provide a function for loading package information from the package index
withLoadPackage :: (StackM env m, HasEnvConfig env)
=> ((PackageLocationIndex FilePath -> Map FlagName Bool -> [Text] -> IO Package) -> m a)
-> m a
withLoadPackage :: HasEnvConfig env
=> ((PackageLocationIndex FilePath -> Map FlagName Bool -> [Text] -> IO Package) -> RIO env a)
-> RIO env a
withLoadPackage inner = do
econfig <- view envConfigL
menv <- getMinimalEnvOverride
Expand All @@ -300,8 +300,8 @@ withLoadPackage inner = do

-- | Set the code page for this process as necessary. Only applies to Windows.
-- See: https://github.com/commercialhaskell/stack/issues/738
fixCodePage :: HasEnvConfig env => RIO env a -> RIO env a
#ifdef WINDOWS
fixCodePage :: (StackM env m, HasBuildConfig env, HasEnvConfig env) => m a -> m a
fixCodePage inner = do
mcp <- view $ configL.to configModifyCodePage
ghcVersion <- view $ actualCompilerVersionL.to getGhcVersion
Expand Down Expand Up @@ -343,14 +343,13 @@ fixCodePage inner = do
, " codepage to UTF-8 (65001) to ensure correct output from GHC"
]
#else
fixCodePage :: a -> a
fixCodePage = id
#endif

-- | Query information about the build and print the result to stdout in YAML format.
queryBuildInfo :: (StackM env m, HasEnvConfig env)
queryBuildInfo :: HasEnvConfig env
=> [Text] -- ^ selectors
-> m ()
-> RIO env ()
queryBuildInfo selectors0 =
rawBuildInfo
>>= select id selectors0
Expand All @@ -375,7 +374,7 @@ queryBuildInfo selectors0 =
err msg = throwString $ msg ++ ": " ++ show (front [sel])

-- | Get the raw build information object
rawBuildInfo :: (StackM env m, HasEnvConfig env) => m Value
rawBuildInfo :: HasEnvConfig env => RIO env Value
rawBuildInfo = do
(locals, _sourceMap) <- loadSourceMap NeedTargets defaultBuildOptsCLI
return $ object
Expand Down
21 changes: 11 additions & 10 deletions src/Stack/Build/ConstructPlan.hs
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,6 @@ module Stack.Build.ConstructPlan
) where

import Stack.Prelude
import Control.Monad.Logger (runLoggingT)
import Control.Monad.RWS.Strict
import Control.Monad.State.Strict (execState)
import qualified Data.HashSet as HashSet
Expand Down Expand Up @@ -56,6 +55,7 @@ import Stack.Types.GhcPkgId
import Stack.Types.Package
import Stack.Types.PackageIdentifier
import Stack.Types.PackageName
import Stack.Types.Runner
import Stack.Types.Version
import System.IO (putStrLn)
import System.Process.Read (findExecutable)
Expand Down Expand Up @@ -118,7 +118,7 @@ instance Monoid W where
mempty = memptydefault
mappend = mappenddefault

type M = RWST
type M = RWST -- TODO replace with more efficient WS stack on top of StackT
Ctx
W
(Map PackageName (Either ConstructPlanException AddDepRes))
Expand All @@ -136,11 +136,14 @@ data Ctx = Ctx
, getVersions :: !(PackageName -> IO (Set Version))
, wanted :: !(Set PackageName)
, localNames :: !(Set PackageName)
, logFunc :: Loc -> LogSource -> LogLevel -> LogStr -> IO ()
}

instance HasPlatform Ctx
instance HasGHCVariant Ctx
instance HasLogFunc Ctx where
logFuncL = configL.logFuncL
instance HasRunner Ctx where
runnerL = configL.runnerL
instance HasConfig Ctx
instance HasBuildConfig Ctx
instance HasEnvConfig Ctx where
Expand All @@ -162,7 +165,7 @@ instance HasEnvConfig Ctx where
--
-- 3) It will only rebuild a local package if its files are dirty or
-- some of its dependencies have changed.
constructPlan :: forall env m. (StackM env m, HasEnvConfig env)
constructPlan :: forall env. HasEnvConfig env
=> LoadedSnapshot
-> BaseConfigOpts
-> [LocalPackage]
Expand All @@ -172,7 +175,7 @@ constructPlan :: forall env m. (StackM env m, HasEnvConfig env)
-> SourceMap
-> InstalledMap
-> Bool
-> m Plan
-> RIO env Plan
constructPlan ls0 baseConfigOpts0 locals extraToBuild0 localDumpPkgs loadPackage0 sourceMap installedMap initialBuildSteps = do
$logDebug "Constructing the build plan"
u <- askUnliftIO
Expand All @@ -182,10 +185,9 @@ constructPlan ls0 baseConfigOpts0 locals extraToBuild0 localDumpPkgs loadPackage
let inner = do
mapM_ onWanted $ filter lpWanted locals
mapM_ (addDep False) $ Set.toList extraToBuild0
lf <- askLoggerIO
lp <- getLocalPackages
((), m, W efinals installExes dirtyReason deps warnings parents) <-
liftIO $ runRWST inner (ctx econfig (unliftIO u . getPackageVersions) lf lp) M.empty
liftIO $ runRWST inner (ctx econfig (unliftIO u . getPackageVersions) lp) M.empty
mapM_ $logWarn (warnings [])
let toEither (_, Left e) = Left e
toEither (k, Right v) = Right (k, v)
Expand Down Expand Up @@ -217,7 +219,7 @@ constructPlan ls0 baseConfigOpts0 locals extraToBuild0 localDumpPkgs loadPackage
$prettyError $ pprintExceptions errs stackYaml parents (wantedLocalPackages locals)
throwM $ ConstructPlanFailed "Plan construction failed."
where
ctx econfig getVersions0 lf lp = Ctx
ctx econfig getVersions0 lp = Ctx
{ ls = ls0
, baseConfigOpts = baseConfigOpts0
, loadPackage = loadPackage0
Expand All @@ -231,7 +233,6 @@ constructPlan ls0 baseConfigOpts0 locals extraToBuild0 localDumpPkgs loadPackage
, getVersions = getVersions0
, wanted = wantedLocalPackages locals <> extraToBuild0
, localNames = Set.fromList $ map (packageName . lpPackage) locals
, logFunc = lf
}

toolMap = getToolMap ls0
Expand Down Expand Up @@ -666,7 +667,7 @@ checkDirtiness :: PackageSource
-> M Bool
checkDirtiness ps installed package present wanted = do
ctx <- ask
moldOpts <- liftIO $ flip runLoggingT (logFunc ctx) $ flip runReaderT ctx $ tryGetFlagCache installed
moldOpts <- runRIO ctx $ tryGetFlagCache installed
let configOpts = configureOpts
(view envConfigL ctx)
(baseConfigOpts ctx)
Expand Down
Loading

0 comments on commit 98c5452

Please sign in to comment.