CurryInfo: cpm-3.3.0 / CPM.Diff.API.compareModulesInDirs

definition:
compareModulesInDirs :: Config -> Repository -> GC.GlobalCache -> String
                     -> String -> Maybe [String]
                     -> ErrorLogger [(String, Differences)]
compareModulesInDirs cfg repo gc dirA dirB onlyMods =
  loadPackageSpec dirA >>= \pkgA ->
  loadPackageSpec dirB >>= \pkgB ->
  resolveAndCopyDependencies cfg repo gc dirA >>= \depsA ->
  resolveAndCopyDependencies cfg repo gc dirB >>= \depsB ->
  let cmpmods = nub (exportedModules pkgA ++ exportedModules pkgB) in
  if null cmpmods
    then logInfo "No exported modules to compare" >> return []
    else do diffs <- liftIOEL $ mapM (compareApiModule
                       pkgA dirA depsA pkgB dirB depsB) cmpmods
            let modsWithDiffs = zip cmpmods diffs
            return $ case onlyMods of
              Nothing -> modsWithDiffs
              Just ms -> filter ((`elem` ms) . fst) modsWithDiffs
demand:
no demanded arguments
deterministic:
deterministic operation
documentation:
--- Compares package versions from two directories.
---
--- @param cfg - the CPM configuration
--- @param repo - the central package index
--- @param gc - the global package cache
--- @param dirA - the directory containing package version A
--- @param dirB - the directory containing package version B
--- @param onlyMods - a list of modules to compare
failfree:
<FAILING>
indeterministic:
referentially transparent operation
infix:
no fixity defined
iotype:
{(_,_,_,_,_,_) |-> _}
name:
compareModulesInDirs
precedence:
no precedence defined
result-values:
_
signature:
CPM.Config.Config -> CPM.Repository.Repository
-> CPM.PackageCache.Global.GlobalCache -> String -> String
-> Prelude.Maybe [String]
-> CPM.ErrorLogger.ErrorLogger [(String, (Prelude.Maybe (Difference String), [Difference AbstractCurry.Types.CFuncDecl], [Difference AbstractCurry.Types.CTypeDecl], [Difference AbstractCurry.Types.COpDecl]))]
solution-complete:
operation might suspend on free variables
terminating:
possibly non-terminating
totally-defined:
possibly non-reducible on same data term