2016-09-27 19:01:08 +00:00
|
|
|
/* Distributed under the OSI-approved BSD 3-Clause License. See accompanying
|
|
|
|
file Copyright.txt or https://cmake.org/licensing for details. */
|
2016-04-29 13:40:20 +00:00
|
|
|
|
2016-11-22 23:41:44 +00:00
|
|
|
#include <cmConfigure.h> // IWYU pragma: keep
|
|
|
|
|
2016-04-29 14:53:13 +00:00
|
|
|
#include <cmsys/Process.h>
|
2016-11-22 23:41:44 +00:00
|
|
|
#include <iostream>
|
|
|
|
#include <string>
|
|
|
|
#include <vector>
|
|
|
|
|
|
|
|
#include "cmSystemTools.h"
|
2006-03-30 22:26:21 +00:00
|
|
|
|
2006-03-31 18:17:23 +00:00
|
|
|
// This is a wrapper program for xcodebuild
|
|
|
|
// it calls xcodebuild, and does two things
|
2012-02-26 18:44:20 +00:00
|
|
|
// it removes much of the output, all the setenv
|
2006-03-31 18:17:23 +00:00
|
|
|
// stuff. Also, it checks for the text file busy
|
|
|
|
// error, and re-runs xcodebuild until that error does
|
|
|
|
// not show up.
|
|
|
|
|
2006-03-30 22:26:21 +00:00
|
|
|
int RunXCode(std::vector<const char*>& argv, bool& hitbug)
|
|
|
|
{
|
|
|
|
hitbug = false;
|
|
|
|
cmsysProcess* cp = cmsysProcess_New();
|
|
|
|
cmsysProcess_SetCommand(cp, &*argv.begin());
|
|
|
|
cmsysProcess_SetTimeout(cp, 0);
|
|
|
|
cmsysProcess_Execute(cp);
|
|
|
|
std::vector<char> out;
|
|
|
|
std::vector<char> err;
|
|
|
|
std::string line;
|
2006-04-04 17:04:28 +00:00
|
|
|
int pipe = cmSystemTools::WaitForLine(cp, line, 100.0, out, err);
|
2016-05-16 14:34:04 +00:00
|
|
|
while (pipe != cmsysProcess_Pipe_None) {
|
|
|
|
if (line.find("/bin/sh: bad interpreter: Text file busy") != line.npos) {
|
2006-03-30 22:26:21 +00:00
|
|
|
hitbug = true;
|
2006-03-31 18:17:23 +00:00
|
|
|
std::cerr << "Hit xcodebuild bug : " << line << "\n";
|
2016-05-16 14:34:04 +00:00
|
|
|
}
|
2006-03-30 22:26:21 +00:00
|
|
|
// if the bug is hit, no more output should be generated
|
|
|
|
// because it may contain bogus errors
|
2006-03-31 18:17:23 +00:00
|
|
|
// also remove all output with setenv in it to tone down
|
|
|
|
// the verbosity of xcodebuild
|
2016-05-16 14:34:04 +00:00
|
|
|
if (!hitbug && (line.find("setenv") == line.npos)) {
|
|
|
|
if (pipe == cmsysProcess_Pipe_STDERR) {
|
2006-03-31 18:17:23 +00:00
|
|
|
std::cerr << line << "\n";
|
2016-05-16 14:34:04 +00:00
|
|
|
} else if (pipe == cmsysProcess_Pipe_STDOUT) {
|
2006-03-31 18:17:23 +00:00
|
|
|
std::cout << line << "\n";
|
2006-03-30 22:26:21 +00:00
|
|
|
}
|
|
|
|
}
|
2016-05-16 14:34:04 +00:00
|
|
|
pipe = cmSystemTools::WaitForLine(cp, line, 100, out, err);
|
|
|
|
}
|
2006-03-30 22:26:21 +00:00
|
|
|
cmsysProcess_WaitForExit(cp, 0);
|
2016-05-16 14:34:04 +00:00
|
|
|
if (cmsysProcess_GetState(cp) == cmsysProcess_State_Exited) {
|
2006-03-30 22:26:21 +00:00
|
|
|
return cmsysProcess_GetExitValue(cp);
|
2016-05-16 14:34:04 +00:00
|
|
|
}
|
|
|
|
if (cmsysProcess_GetState(cp) == cmsysProcess_State_Error) {
|
2006-03-30 22:26:21 +00:00
|
|
|
return -1;
|
2016-05-16 14:34:04 +00:00
|
|
|
}
|
2006-03-30 22:26:21 +00:00
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
2016-05-16 14:34:04 +00:00
|
|
|
int main(int ac, char* av[])
|
2012-08-13 17:42:58 +00:00
|
|
|
{
|
2006-03-30 22:26:21 +00:00
|
|
|
std::vector<const char*> argv;
|
|
|
|
argv.push_back("xcodebuild");
|
2016-05-16 14:34:04 +00:00
|
|
|
for (int i = 1; i < ac; i++) {
|
2006-03-30 22:26:21 +00:00
|
|
|
argv.push_back(av[i]);
|
2016-05-16 14:34:04 +00:00
|
|
|
}
|
2006-03-30 22:26:21 +00:00
|
|
|
argv.push_back(0);
|
|
|
|
bool hitbug = true;
|
2006-03-31 18:17:23 +00:00
|
|
|
int ret = 0;
|
2016-05-16 14:34:04 +00:00
|
|
|
while (hitbug) {
|
2006-03-30 22:26:21 +00:00
|
|
|
ret = RunXCode(argv, hitbug);
|
2016-05-16 14:34:04 +00:00
|
|
|
}
|
|
|
|
if (ret < 0) {
|
2006-03-30 22:26:21 +00:00
|
|
|
return 255;
|
2016-05-16 14:34:04 +00:00
|
|
|
}
|
2006-03-30 22:26:21 +00:00
|
|
|
return ret;
|
|
|
|
}
|