private static bool BuildDepsParallel(ModulesOrder modulesOrder, BuiltInfoStorage builtStorage, List <Dep> modulesToBuild, ModuleBuilder builder) { var parallelBuilder = new ParallelBuilder(modulesOrder.ConfigsGraph); var tasks = new List <Task>(); var builtCount = 1; for (int i = 0; i < Helper.MaxDegreeOfParallelism; i++) { tasks.Add(Task.Run(() => { while (true) { var dep = parallelBuilder.TryStartBuild(); if (dep == null) { return; } if (dep.Equals(modulesOrder.BuildOrder.LastOrDefault())) { parallelBuilder.EndBuild(dep); continue; } if (NoNeedToBuild(dep, modulesToBuild)) { parallelBuilder.EndBuild(dep); lock (builtStorage) builtStorage.AddBuiltModule(dep, modulesOrder.CurrentCommitHashes); continue; } ConsoleWriter.WriteProgress($"{dep.ToBuildString(),-49} {$"{builtCount}/{modulesToBuild.Count}",10}"); var success = builder.Build(dep); parallelBuilder.EndBuild(dep, !success); if (success) { lock (builtStorage) { builtStorage.AddBuiltModule(dep, modulesOrder.CurrentCommitHashes); builtCount++; } } } })); } Task.WaitAll(tasks.ToArray()); builtStorage.Save(); Log.LogDebug("msbuild time: " + new TimeSpan(ModuleBuilder.TotalMsbuildTime)); return(!parallelBuilder.IsFailed); }
//Определение порядка вычисления модулей internal void MakeModuleGraph(TablikModule m) { m.DfsStatus = DfsStatus.Process; foreach (var lm in m.LinkedModules) { if (lm.DfsStatus == DfsStatus.Before) { MakeModuleGraph(lm); } else if (lm.DfsStatus == DfsStatus.Process) { AddWarning("Циклическая зависимость модулей", null, lm.Code); } } ModulesOrder.Add(m); m.DfsStatus = DfsStatus.After; }
private static bool BuildDepsSequential(ModulesOrder modulesOrder, BuildInfoStorage buildStorage, List <Dep> modulesToBuild, ModuleBuilder builder) { var built = 1; for (var i = 0; i < modulesOrder.BuildOrder.Count - 1; i++) { var dep = modulesOrder.BuildOrder[i]; if (NoNeedToBuild(dep, modulesToBuild)) { buildStorage.AddBuiltModule(dep, modulesOrder.CurrentCommitHashes); continue; } ConsoleWriter.Shared.WriteProgress($"{dep.ToBuildString(),-49} {$"{built}/{modulesToBuild.Count}",10}"); try { if (!builder.Build(dep)) { buildStorage.Save(); return(false); } } catch (Exception) { buildStorage.Save(); throw; } buildStorage.AddBuiltModule(dep, modulesOrder.CurrentCommitHashes); built++; } buildStorage.Save(); Log.LogDebug("msbuild time: " + new TimeSpan(ModuleBuilder.TotalMsbuildTime)); return(true); }
//Компиляция выбранных модулей public void Compile() { if (Modules.Count == 0) { return; } ModulesOrder.Clear(); foreach (var m in Modules.Values) { m.DfsStatus = DfsStatus.Before; } foreach (var m in Modules.Values) { if (m.DfsStatus == DfsStatus.Before) { MakeModuleGraph(m); } } foreach (var m in ModulesOrder) { m.Compile(); } }