Skip to content

Commit

Permalink
rdmd.d: Capture stderr when calculating dependencies
Browse files Browse the repository at this point in the history
When invoking the compiler to calculate dependencies capture both
stdout and stderr since gdc's verbose output goes to stderr.

Signed-off-by: Andrei Horodniceanu <[email protected]>
  • Loading branch information
the-horo committed Apr 26, 2024
1 parent 1a8c1a9 commit a0dc43e
Showing 1 changed file with 12 additions and 5 deletions.
17 changes: 12 additions & 5 deletions rdmd.d
Original file line number Diff line number Diff line change
Expand Up @@ -140,7 +140,7 @@ int main(string[] args)
string[] eval; // set by --eval
bool makeDepend;
string makeDepFile;

try
{
getopt(argsBeforeProgram,
Expand Down Expand Up @@ -182,7 +182,7 @@ int main(string[] args)
if (!compiler)
{
compiler = defaultCompiler;

// Look for the D compiler rdmd invokes automatically in the same directory as rdmd
// and fall back to using the one in your path otherwise.
string compilerPath = buildPath(dirName(thisExePath()), compiler ~ binExt);
Expand Down Expand Up @@ -576,7 +576,7 @@ private int rebuild(string root, string fullExe,
// Run a program optionally writing the command line first
// If "replace" is true and the OS supports it, replace the current process.

private int run(string[] args, string output = null, bool replace = false)
private int run(string[] args, string output = null, bool replace = false, bool captureStderr = false)
{
import std.conv;
yap(replace ? "exec " : "spawn ", args.text);
Expand All @@ -599,7 +599,12 @@ private int run(string[] args, string output = null, bool replace = false)
outputFile = File(output, "wb");
else
outputFile = stdout;
auto process = spawnProcess(args, stdin, outputFile);
File stderrFile;
if (captureStderr)
stderrFile = outputFile;
else
stderrFile = stderr;
auto process = spawnProcess(args, stdin, outputFile, stderrFile);
return process.wait();
}

Expand Down Expand Up @@ -744,7 +749,9 @@ private string[string] getDependencies(string rootModule, string workDir,
collectException(Filesystem.remove(depsFilename));
}

immutable depsExitCode = run(depsGetter, depsFilename);
// gdc prints -v on stderr, ldc2 and dmd use stdout
immutable depsExitCode = run(depsGetter, depsFilename,
/*replace=*/false, /*captureStderr=*/true);
if (depsExitCode)
{
stderr.writefln("Failed: %s", depsGetter);
Expand Down

0 comments on commit a0dc43e

Please sign in to comment.