This is required on my Fedora 21 system, but not on Ubuntu based systems I tested.
Maybe it has something to do with the default shell being used?
Details
Diff Detail
Event Timeline
test/tools/llvm-config/flush-stdout.test | ||
---|---|---|
1 | Please use FileCheck instead of grep... we're trying to eliminate grep from testcases (slowly). |
This is confusing, shouldn't the destructor of the object behind outs() take care of the flushing on program exit?
The destructor does normally flush, but I think the what is happening is that the file descriptor is closed before the destructor is called, so the flush doesn't do anything.
What's happening is that the destructor at least of the static variable in llvm::outs() doesn't run when LLVM_LINK_TOOLS_DYLIB is enabled. Probably this affects other global variables as well.
I ran into this again and decided to investigate a bit more. The root cause is r223805, which explicitly disables atexit for the dynamic library build.
This behaviour is controlled by LLVM_DISABLE_LLVM_DYLIB_ATEXIT, which tries to default to OFF when the tools (i.e. llvm-config) is linked against the dynamic library. As far as I can tell, the problem is basically that we did (as one is likely to do):
- Set up a dylib build. This sets LLVM_DISABLE_LLVM_DYLIB_ATEXIT to ON.
- Notice that all the tool executables become gigantic and turn on LLVM_LINK_LLVM_DYLIB.
- Oops, CMake remembers the old setting of LLVM_DISABLE_LLVM_DYLIB_ATEXIT and llvm-config is now unusable from build scripts.
So while explicitly setting LLVM_DISABLE_LLVM_DYLIB_ATEXIT to OFF is a (extremely hard to discover) workaround, this really needs to be fixed somehow.
Please use FileCheck instead of grep... we're trying to eliminate grep from testcases (slowly).