示例#1
0
        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);
        }
示例#2
0
 //Определение порядка вычисления модулей
 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;
 }
示例#3
0
        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);
        }
示例#4
0
        //Компиляция выбранных модулей
        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();
            }
        }