From b551c4a9609e98b4e083bf63f51fdeb10ba6430b Mon Sep 17 00:00:00 2001 From: Kristen Kozak Date: Sun, 11 Nov 2018 20:43:03 -0800 Subject: [PATCH] Use RetryLog when rerunning the solver. RetryLog is simpler and more efficient than Progress for continuing the solver log after an error. --- cabal-install/Distribution/Solver/Modular.hs | 47 +++++++++---------- .../Distribution/Solver/Modular/Log.hs | 10 ++-- 2 files changed, 28 insertions(+), 29 deletions(-) diff --git a/cabal-install/Distribution/Solver/Modular.hs b/cabal-install/Distribution/Solver/Modular.hs index 28023572128..791189544bd 100644 --- a/cabal-install/Distribution/Solver/Modular.hs +++ b/cabal-install/Distribution/Solver/Modular.hs @@ -1,3 +1,5 @@ +{-# LANGUAGE LambdaCase #-} + module Distribution.Solver.Modular ( modularResolver, SolverConfig(..), PruneAfterFirstSuccess(..) ) where @@ -30,9 +32,10 @@ import Distribution.Solver.Modular.Index import Distribution.Solver.Modular.IndexConversion ( convPIs ) import Distribution.Solver.Modular.Log - ( SolverFailure(..), logToProgress ) + ( SolverFailure(..), displayLogMessages ) import Distribution.Solver.Modular.Package ( PN ) +import Distribution.Solver.Modular.RetryLog import Distribution.Solver.Modular.Solver ( SolverConfig(..), PruneAfterFirstSuccess(..), solve ) import Distribution.Solver.Types.DependencyResolver @@ -116,40 +119,36 @@ solve' :: SolverConfig -> Set PN -> Progress String String (Assignment, RevDepMap) solve' sc cinfo idx pkgConfigDB pprefs gcs pns = - foldProgress Step - (createErrorMsg (solverVerbosity sc) (maxBackjumps sc)) - Done - (runSolver printFullLog sc) + toProgress $ retry (runSolver printFullLog sc) + (createErrorMsg (solverVerbosity sc) (maxBackjumps sc)) where runSolver :: Bool -> SolverConfig - -> Progress String SolverFailure (Assignment, RevDepMap) + -> RetryLog String SolverFailure (Assignment, RevDepMap) runSolver keepLog sc' = - logToProgress keepLog $ + displayLogMessages keepLog $ solve sc' cinfo idx pkgConfigDB pprefs gcs pns createErrorMsg :: Verbosity -> Maybe Int -> SolverFailure - -> Progress String String (Assignment, RevDepMap) + -> RetryLog String String (Assignment, RevDepMap) createErrorMsg verbosity mbj failure@(ExhaustiveSearch cs _) = - Fail $ rerunSolverForErrorMsg cs ++ finalErrorMsg verbosity mbj failure + fromProgress $ Fail $ rerunSolverForErrorMsg cs ++ finalErrorMsg verbosity mbj failure createErrorMsg verbosity mbj failure@BackjumpLimitReached = - Step ("Backjump limit reached. Rerunning dependency solver to generate " + continueWith ("Backjump limit reached. Rerunning dependency solver to generate " ++ "a final conflict set for the search tree containing the " ++ "first backjump.") $ - foldProgress Step f Done $ - runSolver printFullLog - sc { pruneAfterFirstSuccess = PruneAfterFirstSuccess True } - where - f :: SolverFailure -> Progress String String (Assignment, RevDepMap) - f (ExhaustiveSearch cs _) = - Fail $ rerunSolverForErrorMsg cs ++ finalErrorMsg verbosity mbj failure - f BackjumpLimitReached = - -- This case is possible when the number of goals involved in - -- conflicts is greater than the backjump limit. - Fail $ finalErrorMsg verbosity mbj failure - ++ "Failed to generate a summarized dependency solver " - ++ "log due to low backjump limit." + retry (runSolver printFullLog sc { pruneAfterFirstSuccess = PruneAfterFirstSuccess True }) $ + \case + ExhaustiveSearch cs _ -> + fromProgress $ Fail $ + rerunSolverForErrorMsg cs ++ finalErrorMsg verbosity mbj failure + BackjumpLimitReached -> + -- This case is possible when the number of goals involved in + -- conflicts is greater than the backjump limit. + fromProgress $ Fail $ finalErrorMsg verbosity mbj failure + ++ "Failed to generate a summarized dependency solver " + ++ "log due to low backjump limit." rerunSolverForErrorMsg :: ConflictSet -> String rerunSolverForErrorMsg cs = @@ -162,7 +161,7 @@ solve' sc cinfo idx pkgConfigDB pprefs gcs pns = -- original goal order. goalOrder' = preferGoalsFromConflictSet cs <> fromMaybe mempty (goalOrder sc) - in unlines ("Could not resolve dependencies:" : messages (runSolver True sc')) + in unlines ("Could not resolve dependencies:" : messages (toProgress (runSolver True sc'))) printFullLog = solverVerbosity sc >= verbose diff --git a/cabal-install/Distribution/Solver/Modular/Log.hs b/cabal-install/Distribution/Solver/Modular/Log.hs index 2561e518ab0..321a051070b 100644 --- a/cabal-install/Distribution/Solver/Modular/Log.hs +++ b/cabal-install/Distribution/Solver/Modular/Log.hs @@ -1,5 +1,5 @@ module Distribution.Solver.Modular.Log - ( logToProgress + ( displayLogMessages , SolverFailure(..) ) where @@ -20,10 +20,10 @@ data SolverFailure = -- | Postprocesses a log file. This function discards all log messages and -- avoids calling 'showMessages' if the log isn't needed (specified by -- 'keepLog'), for efficiency. -logToProgress :: Bool - -> RetryLog Message SolverFailure a - -> Progress String SolverFailure a -logToProgress keepLog lg = +displayLogMessages :: Bool + -> RetryLog Message SolverFailure a + -> RetryLog String SolverFailure a +displayLogMessages keepLog lg = fromProgress $ if keepLog then showMessages progress else foldProgress (const id) Fail Done progress