Mono: Fix passing wrong logger assembly path to MSBuild

- Add option to print MSBuild's stdout and stderr instead of redirecting it. This can be enabled by setting the environment variable: Godot_DEBUG_MSBUILD=1

(cherry picked from commit 25f10b3c40)
This commit is contained in:
Ignacio Etcheverry 2018-06-05 22:18:43 +02:00 committed by Hein-Pieter van Braam
parent 84e1551c64
commit 16550339ba
2 changed files with 30 additions and 12 deletions

View File

@ -78,6 +78,8 @@ namespace GodotSharpTools.Build
public bool Build(string loggerAssemblyPath, string loggerOutputDir, string[] customProperties = null) public bool Build(string loggerAssemblyPath, string loggerOutputDir, string[] customProperties = null)
{ {
bool debugMSBuild = IsDebugMSBuildRequested();
List<string> customPropertiesList = new List<string>(); List<string> customPropertiesList = new List<string>();
if (customProperties != null) if (customProperties != null)
@ -92,9 +94,10 @@ namespace GodotSharpTools.Build
ProcessStartInfo startInfo = new ProcessStartInfo(GetMSBuildPath(), compilerArgs); ProcessStartInfo startInfo = new ProcessStartInfo(GetMSBuildPath(), compilerArgs);
// No console output, thanks bool redirectOutput = !debugMSBuild;
startInfo.RedirectStandardOutput = true;
startInfo.RedirectStandardError = true; startInfo.RedirectStandardOutput = redirectOutput;
startInfo.RedirectStandardError = redirectOutput;
startInfo.UseShellExecute = false; startInfo.UseShellExecute = false;
if (UsingMonoMSBuildOnWindows) if (UsingMonoMSBuildOnWindows)
@ -116,8 +119,11 @@ namespace GodotSharpTools.Build
process.Start(); process.Start();
if (redirectOutput)
{
process.BeginOutputReadLine(); process.BeginOutputReadLine();
process.BeginErrorReadLine(); process.BeginErrorReadLine();
}
process.WaitForExit(); process.WaitForExit();
@ -129,6 +135,8 @@ namespace GodotSharpTools.Build
public bool BuildAsync(string loggerAssemblyPath, string loggerOutputDir, string[] customProperties = null) public bool BuildAsync(string loggerAssemblyPath, string loggerOutputDir, string[] customProperties = null)
{ {
bool debugMSBuild = IsDebugMSBuildRequested();
if (process != null) if (process != null)
throw new InvalidOperationException("Already in use"); throw new InvalidOperationException("Already in use");
@ -146,9 +154,10 @@ namespace GodotSharpTools.Build
ProcessStartInfo startInfo = new ProcessStartInfo(GetMSBuildPath(), compilerArgs); ProcessStartInfo startInfo = new ProcessStartInfo(GetMSBuildPath(), compilerArgs);
// No console output, thanks bool redirectOutput = !debugMSBuild;
startInfo.RedirectStandardOutput = true;
startInfo.RedirectStandardError = true; startInfo.RedirectStandardOutput = redirectOutput;
startInfo.RedirectStandardError = redirectOutput;
startInfo.UseShellExecute = false; startInfo.UseShellExecute = false;
if (UsingMonoMSBuildOnWindows) if (UsingMonoMSBuildOnWindows)
@ -171,8 +180,11 @@ namespace GodotSharpTools.Build
process.Start(); process.Start();
if (redirectOutput)
{
process.BeginOutputReadLine(); process.BeginOutputReadLine();
process.BeginErrorReadLine(); process.BeginErrorReadLine();
}
return true; return true;
} }
@ -220,6 +232,11 @@ namespace GodotSharpTools.Build
Dispose(); Dispose();
} }
private static bool IsDebugMSBuildRequested()
{
return Environment.GetEnvironmentVariable("GODOT_DEBUG_MSBUILD").Trim() == "1";
}
public void Dispose() public void Dispose()
{ {
if (process != null) if (process != null)

View File

@ -527,8 +527,9 @@ void GodotSharpBuilds::BuildProcess::start(bool p_blocking) {
// Call Build // Call Build
Variant logger_assembly = OS::get_singleton()->get_executable_path().get_base_dir().plus_file(EDITOR_TOOLS_ASSEMBLY_NAME) + ".dll"; String logger_assembly_path = GDMono::get_singleton()->get_editor_tools_assembly()->get_path();
Variant logger_output_dir = logs_dir; Variant logger_assembly = ProjectSettings::get_singleton()->globalize_path(logger_assembly_path);
Variant logger_output_dir = log_dirpath;
Variant custom_props = build_info.custom_props; Variant custom_props = build_info.custom_props;
const Variant *args[3] = { &logger_assembly, &logger_output_dir, &custom_props }; const Variant *args[3] = { &logger_assembly, &logger_output_dir, &custom_props };