mirror of
https://github.com/reactos/CMake.git
synced 2024-12-20 10:38:08 +00:00
1a2a6ba4b6
Both <string> and <cmSystemTools.h> include <stdio.h> one or the other way. It looks like the CMake header adds a define that will cause another part of the system header to be used, resulting in conflicting definitions.
59 lines
1.2 KiB
C++
59 lines
1.2 KiB
C++
#include <cmSystemTools.h>
|
|
#include <string>
|
|
|
|
#define RETVAL @_retval@
|
|
|
|
int
|
|
main(int argc, char **argv)
|
|
{
|
|
std::string exename = argv[0];
|
|
std::string logarg;
|
|
bool nextarg = false;
|
|
|
|
if (exename.find("valgrind") != exename.npos)
|
|
logarg = "--log-file=";
|
|
else if (exename.find("purify") != exename.npos)
|
|
#ifdef _WIN32
|
|
logarg = "/SAVETEXTDATA=";
|
|
#else
|
|
logarg = "-log-file=";
|
|
#endif
|
|
else if (exename.find("BC") != exename.npos)
|
|
{
|
|
nextarg = true;
|
|
logarg = "/X";
|
|
}
|
|
|
|
if (!logarg.empty()) {
|
|
std::string logfile;
|
|
for (int i = 1; i < argc; i++) {
|
|
std::string arg = argv[i];
|
|
// stop processing options, this allows to force
|
|
// the logfile to be ignored
|
|
if (arg == "--")
|
|
{
|
|
break;
|
|
}
|
|
if (arg.find(logarg) == 0)
|
|
{
|
|
if (nextarg)
|
|
{
|
|
if (i == argc - 1)
|
|
return 1; // invalid command line
|
|
logfile = argv[i + 1];
|
|
}
|
|
else
|
|
{
|
|
logfile = arg.substr(logarg.length());
|
|
}
|
|
break;
|
|
}
|
|
}
|
|
|
|
if (!logfile.empty())
|
|
cmSystemTools::Touch(logfile.c_str(), true);
|
|
}
|
|
|
|
return RETVAL;
|
|
}
|