Ensure we're writing to stderr in the builder

http://hydra.nixos.org/build/17862041
This commit is contained in:
Eelco Dolstra 2014-12-12 14:35:44 +01:00 committed by Ludovic Courtès
parent ccade8c120
commit 5c84e4950d
5 changed files with 21 additions and 19 deletions

View File

@ -2203,7 +2203,7 @@ void DerivationGoal::runChild()
restoreSIGPIPE(); restoreSIGPIPE();
/* Indicate that we managed to set up the build environment. */ /* Indicate that we managed to set up the build environment. */
writeToStderr("\n"); writeFull(STDERR_FILENO, "\n");
/* Execute the program. This should not return. */ /* Execute the program. This should not return. */
execve(program.c_str(), (char * *) &args[0], (char * *) envArr); execve(program.c_str(), (char * *) &args[0], (char * *) envArr);
@ -2211,7 +2211,7 @@ void DerivationGoal::runChild()
throw SysError(format("executing `%1%'") % drv.builder); throw SysError(format("executing `%1%'") % drv.builder);
} catch (std::exception & e) { } catch (std::exception & e) {
writeToStderr("while setting up the build environment: " + string(e.what()) + "\n"); writeFull(STDERR_FILENO, "while setting up the build environment: " + string(e.what()) + "\n");
_exit(1); _exit(1);
} }
@ -2526,7 +2526,7 @@ void DerivationGoal::handleChildOutput(int fd, const string & data)
BZ2_bzWrite(&err, bzLogFile, (unsigned char *) data.data(), data.size()); BZ2_bzWrite(&err, bzLogFile, (unsigned char *) data.data(), data.size());
if (err != BZ_OK) throw Error(format("cannot write to compressed log file (BZip2 error = %1%)") % err); if (err != BZ_OK) throw Error(format("cannot write to compressed log file (BZip2 error = %1%)") % err);
} else if (fdLogFile != -1) } else if (fdLogFile != -1)
writeFull(fdLogFile, (unsigned char *) data.data(), data.size()); writeFull(fdLogFile, data);
} }
if (hook && fd == hook->fromHook.readSide) if (hook && fd == hook->fromHook.readSide)

View File

@ -191,7 +191,7 @@ void LocalStore::addTempRoot(const Path & path)
lockFile(fdTempRoots, ltWrite, true); lockFile(fdTempRoots, ltWrite, true);
string s = path + '\0'; string s = path + '\0';
writeFull(fdTempRoots, (const unsigned char *) s.data(), s.size()); writeFull(fdTempRoots, s);
/* Downgrade to a read lock. */ /* Downgrade to a read lock. */
debug(format("downgrading to read lock on `%1%'") % fnTempRoots); debug(format("downgrading to read lock on `%1%'") % fnTempRoots);
@ -231,7 +231,7 @@ static void readTempRoots(PathSet & tempRoots, FDs & fds)
if (lockFile(*fd, ltWrite, false)) { if (lockFile(*fd, ltWrite, false)) {
printMsg(lvlError, format("removing stale temporary roots file `%1%'") % path); printMsg(lvlError, format("removing stale temporary roots file `%1%'") % path);
unlink(path.c_str()); unlink(path.c_str());
writeFull(*fd, (const unsigned char *) "d", 1); writeFull(*fd, "d");
continue; continue;
} }

View File

@ -33,7 +33,7 @@ void deleteLockFile(const Path & path, int fd)
other processes waiting on this lock that the lock is stale other processes waiting on this lock that the lock is stale
(deleted). */ (deleted). */
unlink(path.c_str()); unlink(path.c_str());
writeFull(fd, (const unsigned char *) "d", 1); writeFull(fd, "d");
/* Note that the result of unlink() is ignored; removing the lock /* Note that the result of unlink() is ignored; removing the lock
file is an optimisation, not a necessity. */ file is an optimisation, not a necessity. */
} }

View File

@ -264,8 +264,8 @@ void writeFile(const Path & path, const string & s)
{ {
AutoCloseFD fd = open(path.c_str(), O_WRONLY | O_TRUNC | O_CREAT, 0666); AutoCloseFD fd = open(path.c_str(), O_WRONLY | O_TRUNC | O_CREAT, 0666);
if (fd == -1) if (fd == -1)
throw SysError(format("opening file `%1%'") % path); throw SysError(format("opening file '%1%'") % path);
writeFull(fd, (unsigned char *) s.data(), s.size()); writeFull(fd, s);
} }
@ -292,7 +292,7 @@ string readLine(int fd)
void writeLine(int fd, string s) void writeLine(int fd, string s)
{ {
s += '\n'; s += '\n';
writeFull(fd, (const unsigned char *) s.data(), s.size()); writeFull(fd, s);
} }
@ -482,18 +482,13 @@ void warnOnce(bool & haveWarned, const FormatOrString & fs)
} }
static void defaultWriteToStderr(const unsigned char * buf, size_t count)
{
writeFull(STDERR_FILENO, buf, count);
}
void writeToStderr(const string & s) void writeToStderr(const string & s)
{ {
try { try {
auto p = _writeToStderr; if (_writeToStderr)
if (!p) p = defaultWriteToStderr; _writeToStderr((const unsigned char *) s.data(), s.size());
p((const unsigned char *) s.data(), s.size()); else
writeFull(STDERR_FILENO, s);
} catch (SysError & e) { } catch (SysError & e) {
/* Ignore failing writes to stderr if we're in an exception /* Ignore failing writes to stderr if we're in an exception
handler, otherwise throw an exception. We need to ignore handler, otherwise throw an exception. We need to ignore
@ -505,7 +500,7 @@ void writeToStderr(const string & s)
} }
void (*_writeToStderr) (const unsigned char * buf, size_t count) = defaultWriteToStderr; void (*_writeToStderr) (const unsigned char * buf, size_t count) = 0;
void readFull(int fd, unsigned char * buf, size_t count) void readFull(int fd, unsigned char * buf, size_t count)
@ -539,6 +534,12 @@ void writeFull(int fd, const unsigned char * buf, size_t count)
} }
void writeFull(int fd, const string & s)
{
writeFull(fd, (const unsigned char *) s.data(), s.size());
}
string drainFD(int fd) string drainFD(int fd)
{ {
string result; string result;

View File

@ -171,6 +171,7 @@ extern void (*_writeToStderr) (const unsigned char * buf, size_t count);
requested number of bytes. */ requested number of bytes. */
void readFull(int fd, unsigned char * buf, size_t count); void readFull(int fd, unsigned char * buf, size_t count);
void writeFull(int fd, const unsigned char * buf, size_t count); void writeFull(int fd, const unsigned char * buf, size_t count);
void writeFull(int fd, const string & s);
MakeError(EndOfFile, Error) MakeError(EndOfFile, Error)