diff options
author | audiofanatic <audiofanatic@gmail.com> | 2009-06-15 20:23:49 +0200 |
---|---|---|
committer | Oswald Buddenhagen <oswald.buddenhagen@nokia.com> | 2009-06-15 20:31:13 +0200 |
commit | 3fd25c90fab85fc6aa9949311b13992c63ba7345 (patch) | |
tree | cf53eed49686919544ff709e16539da3dcdebe44 | |
parent | 4aee3ada19e83f9802832b6e31dcffccb1693522 (diff) | |
download | qt4-tools-3fd25c90fab85fc6aa9949311b13992c63ba7345.tar.gz |
Force line buffering for stdout so it stays in sync better with stderr (which is unbuffered)
Task-number: 254786
Merge-request: 610
Reviewed-by: Oswald Buddenhagen <oswald.buddenhagen@nokia.com>
-rw-r--r-- | qmake/main.cpp | 7 |
1 files changed, 7 insertions, 0 deletions
diff --git a/qmake/main.cpp b/qmake/main.cpp index fe274c4910..7da66ac6f1 100644 --- a/qmake/main.cpp +++ b/qmake/main.cpp @@ -84,6 +84,13 @@ bool qmake_setpwd(const QString &p) int runQMake(int argc, char **argv) { + // stderr is unbuffered by default, but stdout buffering depends on whether + // there is a terminal attached. Buffering can make output from stderr and stdout + // appear out of sync, so force stdout to be line buffered to minimize this without + // hurting performance too much (if at all). This is particularly important for + // things like QtCreator and scripted builds. + setvbuf(stdout, (char *)NULL, _IOLBF, 0); + // parse command line int ret = Option::init(argc, argv); if(ret != Option::QMAKE_CMDLINE_SUCCESS) { |