private static void PrintBuildFailResult(Dep dep, string buildName, BuildScriptWithBuildData script, ShellRunner runner) { ConsoleWriter.Shared.WriteBuildError( $"Failed to build {dep.Name}{(dep.Configuration == null ? "" : "/" + dep.Configuration)} {buildName}"); foreach (var line in runner.Output.Split('\n')) { ModuleBuilderHelper.WriteLine(line); } ConsoleWriter.Shared.WriteLine(); ConsoleWriter.Shared.WriteInfo("Errors summary:"); foreach (var line in runner.Output.Split('\n')) { ModuleBuilderHelper.WriteIfErrorToStandartStream(line); } ConsoleWriter.Shared.WriteLine($"({script.Script})"); }
private bool RunBuildScript(Dep dep, BuildScriptWithBuildData script) { var sw = Stopwatch.StartNew(); var command = script.Script; var runner = PrepareShellRunner(); int exitCode = -1; for (int timesTry = 0; timesTry < 2 && exitCode != 0; timesTry++) { ModuleBuilderHelper.KillMsBuild(log); if (timesTry != 0) { command = script.ScriptIfFail; } log.DebugFormat("Build command: '{0}'", command); if (buildSettings.ShowOutput) { ConsoleWriter.WriteInfo($"BUILDING {command}"); } exitCode = runner.RunInDirectory(Path.Combine(Helper.CurrentWorkspace, dep.Name), command, TimeSpan.FromMinutes(60)); } sw.Stop(); TotalMsbuildTime += sw.Elapsed; var elapsedTime = Helper.ConvertTime(sw.ElapsedMilliseconds); var warnCount = runner.Output.Split('\n').Count(ModuleBuilderHelper.IsWarning); var obsoleteUsages = runner.Output.Split('\n').Where(ModuleBuilderHelper.IsObsoleteWarning).ToList(); var buildName = script.BuildData == null ? "" : script.BuildData.Name; if (exitCode != 0) { PrintBuildFailResult(dep, buildName, runner); return(false); } PrintBuildResult(dep, buildName, warnCount, elapsedTime, obsoleteUsages); return(true); }