本文整理汇总了C++中CompileJob::outputFile方法的典型用法代码示例。如果您正苦于以下问题:C++ CompileJob::outputFile方法的具体用法?C++ CompileJob::outputFile怎么用?C++ CompileJob::outputFile使用的例子?那么, 这里精选的方法代码示例或许可以为您提供帮助。您也可以进一步了解该方法所在类CompileJob
的用法示例。
在下文中一共展示了CompileJob::outputFile方法的7个代码示例,这些例子默认根据受欢迎程度排序。您可以为喜欢或者感觉有用的代码点赞,您的评价将有助于系统推荐出更棒的C++代码示例。
示例1: compile_file
static bool
maybe_build_local(MsgChannel *local_daemon, UseCSMsg *usecs, CompileJob &job,
int &ret)
{
remote_daemon = usecs->hostname;
if (usecs->hostname == "127.0.0.1") {
// If this is a test build, do local builds on the local daemon
// that has --no-remote, use remote building for the remaining ones.
if (getenv("ICECC_TEST_REMOTEBUILD") && usecs->port != 0 )
return false;
trace() << "building myself, but telling localhost\n";
int job_id = usecs->job_id;
job.setJobID(job_id);
job.setEnvironmentVersion("__client");
CompileFileMsg compile_file(&job);
if (!local_daemon->send_msg(compile_file)) {
log_info() << "write of job failed" << endl;
throw(29);
}
struct timeval begintv, endtv;
struct rusage ru;
gettimeofday(&begintv, 0);
ret = build_local(job, local_daemon, &ru);
gettimeofday(&endtv, 0);
// filling the stats, so the daemon can play proxy for us
JobDoneMsg msg(job_id, ret, JobDoneMsg::FROM_SUBMITTER);
msg.real_msec = (endtv.tv_sec - begintv.tv_sec) * 1000 + (endtv.tv_usec - begintv.tv_usec) / 1000;
struct stat st;
if (!stat(job.outputFile().c_str(), &st)) {
msg.out_uncompressed = st.st_size;
}
msg.user_msec = ru.ru_utime.tv_sec * 1000 + ru.ru_utime.tv_usec / 1000;
msg.sys_msec = ru.ru_stime.tv_sec * 1000 + ru.ru_stime.tv_usec / 1000;
msg.pfaults = ru.ru_majflt + ru.ru_minflt + ru.ru_nswap;
msg.exitcode = ret;
if (msg.user_msec > 50 && msg.out_uncompressed > 1024) {
trace() << "speed=" << float(msg.out_uncompressed / msg.user_msec) << endl;
}
return local_daemon->send_msg(msg);
}
return false;
}
示例2: build_remote
//.........这里部分代码省略.........
}
char rand_seed[400]; // "designed to be oversized" (Levi's)
sprintf( rand_seed, "-frandom-seed=%d", rand() );
job.appendFlag( rand_seed, Arg_Remote );
GetCSMsg getcs (envs, get_absfilename( job.inputFile() ), job.language(), torepeat,
job.targetPlatform(), job.argumentFlags(), preferred_host ? preferred_host : string(),
ignore_unverified());
if (!local_daemon->send_msg (getcs)) {
log_warning() << "asked for CS\n";
throw( 0 );
}
map<pid_t, int> jobmap;
CompileJob *jobs = new CompileJob[torepeat];
UseCSMsg **umsgs = new UseCSMsg*[torepeat];
bool misc_error = false;
int *exit_codes = new int[torepeat];
for ( int i = 0; i < torepeat; i++ ) // init
exit_codes[i] = 42;
for ( int i = 0; i < torepeat; i++ ) {
jobs[i] = job;
char *buffer = 0;
if ( i ) {
dcc_make_tmpnam( "icecc", ".o", &buffer, 0 );
jobs[i].setOutputFile( buffer );
} else
buffer = strdup( job.outputFile().c_str() );
const CharBufferDeleter buffer_holder( buffer );
umsgs[i] = get_server( local_daemon );
remote_daemon = umsgs[i]->hostname;
trace() << "got_server_for_job " << umsgs[i]->hostname << endl;
flush_debug();
pid_t pid = fork();
if ( !pid ) {
int ret = 42;
try {
if (!maybe_build_local (local_daemon, umsgs[i], jobs[i], ret))
ret = build_remote_int(
jobs[i], umsgs[i], local_daemon,
version_map[umsgs[i]->host_platform],
versionfile_map[umsgs[i]->host_platform],
preproc, i == 0 );
} catch ( int error ) {
log_info() << "build_remote_int failed and has thrown " << error << endl;
kill( getpid(), SIGTERM );
return 0; // shouldn't matter
}
_exit( ret );
return 0; // doesn't matter
} else {
jobmap[pid] = i;
}
}
for ( int i = 0; i < torepeat; i++ ) {
pid_t pid = wait( &status );
if ( pid < 0 ) {
log_perror( "wait failed" );
示例3: build_remote_int
//.........这里部分代码省略.........
check_for_failure( msg, cserver );
if ( msg->type != M_COMPILE_RESULT ) {
log_warning() << "waited for compile result, but got " << (char)msg->type << endl;
delete msg;
throw( 13 );
}
CompileResultMsg *crmsg = dynamic_cast<CompileResultMsg*>( msg );
assert ( crmsg );
status = crmsg->status;
if ( status && crmsg->was_out_of_memory ) {
delete crmsg;
log_info() << "the server ran out of memory, recompiling locally" << endl;
throw( 17 ); // recompile locally - TODO: handle this as a normal local job not an error case
}
if ( output )
{
write(STDOUT_FILENO, crmsg->out.c_str(), crmsg->out.size() );
if(colorify_wanted(job))
colorify_output(crmsg->err);
else
write(STDERR_FILENO, crmsg->err.c_str(), crmsg->err.size() );
if ( status && ( crmsg->err.length() || crmsg->out.length() ) )
{
log_error() << "Compiled on " << hostname << endl;
}
}
delete crmsg;
assert( !job.outputFile().empty() );
if( status == 0 ) {
string tmp_file = job.outputFile() + "_icetmp";
int obj_fd = open( tmp_file.c_str(), O_CREAT|O_TRUNC|O_WRONLY|O_LARGEFILE, 0666 );
if ( obj_fd == -1 ) {
std::string errmsg("can't create ");
errmsg += tmp_file + ":";
log_perror(errmsg.c_str());
return EXIT_DISTCC_FAILED;
}
msg = 0;
size_t uncompressed = 0;
size_t compressed = 0;
while ( 1 ) {
delete msg;
msg = cserver->get_msg(40);
if ( !msg ) { // the network went down?
unlink( tmp_file.c_str());
throw ( 19 );
}
check_for_failure( msg, cserver );
if ( msg->type == M_END )
break;
if ( msg->type != M_FILE_CHUNK ) {
unlink( tmp_file.c_str());
delete msg;
throw ( 20 );
}
FileChunkMsg *fcmsg = dynamic_cast<FileChunkMsg*>( msg );
compressed += fcmsg->compressed;
uncompressed += fcmsg->len;
if ( write( obj_fd, fcmsg->buffer, fcmsg->len ) != ( ssize_t )fcmsg->len ) {
unlink( tmp_file.c_str());
delete msg;
throw ( 21 );
}
}
if (uncompressed)
trace() << "got " << compressed << " bytes ("
<< (compressed * 100 / uncompressed) << "%)" << endl;
delete msg;
if( close( obj_fd ) == 0 )
rename( tmp_file.c_str(), job.outputFile().c_str());
else
unlink( tmp_file.c_str());
}
} catch ( int x ) {
delete cserver;
cserver = 0;
throw( x );
}
delete cserver;
return status;
}
示例4: main
//.........这里部分代码省略.........
// the timeout is high because it creates the native version
Msg *umsg = local_daemon->get_msg(4 * 60);
string native;
if (umsg && umsg->type == M_NATIVE_ENV) {
native = static_cast<UseNativeEnvMsg*>(umsg)->nativeVersion;
}
if (native.empty() || ::access(native.c_str(), R_OK)) {
log_warning() << "daemon can't determine native environment. "
"Set $ICECC_VERSION to an icecc environment.\n";
} else {
envs.push_back(make_pair(job.targetPlatform(), native));
log_info() << "native " << native << endl;
}
delete umsg;
}
// we set it to local so we tell the local daemon about it - avoiding file locking
if (envs.size() == 0) {
local = true;
}
for (Environments::const_iterator it = envs.begin(); it != envs.end(); ++it) {
trace() << "env: " << it->first << " '" << it->second << "'" << endl;
if (::access(it->second.c_str(), R_OK)) {
log_error() << "can't read environment " << it->second << endl;
local = true;
}
}
}
int ret;
if (local) {
log_block b("building_local");
struct rusage ru;
Msg *startme = 0L;
/* Inform the daemon that we like to start a job. */
if (local_daemon->send_msg(JobLocalBeginMsg(0, get_absfilename(job.outputFile())))) {
/* Now wait until the daemon gives us the start signal. 40 minutes
should be enough for all normal compile or link jobs. */
startme = local_daemon->get_msg(40 * 60);
}
/* If we can't talk to the daemon anymore we need to fall back
to lock file locking. */
if (!startme || startme->type != M_JOB_LOCAL_BEGIN) {
goto do_local_error;
}
ret = build_local(job, local_daemon, &ru);
} else {
try {
// check if it should be compiled three times
const char *s = getenv("ICECC_REPEAT_RATE");
int rate = s ? atoi(s) : 0;
ret = build_remote(job, local_daemon, envs, rate);
/* We have to tell the local daemon that everything is fine and
that the remote daemon will send the scheduler our done msg.
If we don't, the local daemon will have to assume the job failed
and tell the scheduler - and that fail message may arrive earlier
than the remote daemon's success msg. */
if (ret == 0) {
local_daemon->send_msg(EndMsg());
}
} catch (int error) {
if (error >= 100) {
log_info() << "local build forced by error " << error << endl;
goto do_local_error;
}
if (remote_daemon.size()) {
log_error() << "got exception " << error
<< " (" << remote_daemon.c_str() << ") " << endl;
} else {
log_error() << "got exception " << error << " (this should be an exception!)" <<
endl;
}
/* currently debugging a client? throw an error then */
if (debug_level != Error) {
return error;
}
goto do_local_error;
}
}
delete local_daemon;
return ret;
do_local_error:
delete local_daemon;
return build_local(job, 0);
}
示例5: build_local
/**
* Invoke a compiler locally. This is, obviously, the alternative to
* dcc_compile_remote().
*
* The server does basically the same thing, but it doesn't call this
* routine because it wants to overlap execution of the compiler with
* copying the input from the network.
*
* This routine used to exec() the compiler in place of distcc. That
* is slightly more efficient, because it avoids the need to create,
* schedule, etc another process. The problem is that in that case we
* can't clean up our temporary files, and (not so important) we can't
* log our resource usage.
*
**/
int build_local(CompileJob &job, MsgChannel *local_daemon, struct rusage *used)
{
list<string> arguments;
string compiler_name = find_compiler(job);
trace() << "invoking: " << compiler_name << endl;
if (compiler_name.empty()) {
log_error() << "could not find " << job.compilerName() << " in PATH." << endl;
return EXIT_NO_SUCH_FILE;
}
arguments.push_back(compiler_name);
appendList(arguments, job.allFlags());
if (!job.inputFile().empty()) {
arguments.push_back(job.inputFile());
}
if (!job.outputFile().empty()) {
arguments.push_back("-o");
arguments.push_back(job.outputFile());
}
char **argv = new char*[arguments.size() + 1];
int argc = 0;
for (list<string>::const_iterator it = arguments.begin(); it != arguments.end(); ++it) {
argv[argc++] = strdup(it->c_str());
}
argv[argc] = 0;
#if CLIENT_DEBUG
trace() << "execing ";
for (int i = 0; argv[i]; i++) {
trace() << argv[i] << " ";
}
trace() << endl;
#endif
if (!local_daemon) {
int fd;
if (!dcc_lock_host(fd)) {
log_error() << "can't lock for local job" << endl;
return EXIT_DISTCC_FAILED;
}
lock_fd = fd;
}
bool color_output = job.language() != CompileJob::Lang_Custom
&& colorify_wanted(job);
int pf[2];
if (color_output && pipe(pf)) {
color_output = false;
}
if (used || color_output) {
flush_debug();
child_pid = fork();
}
if (!child_pid) {
dcc_increment_safeguard();
if (color_output) {
close(pf[0]);
close(2);
dup2(pf[1], 2);
}
int ret = execv(argv[0], argv);
if (lock_fd) {
dcc_unlock(lock_fd);
}
if (ret) {
char buf[256];
snprintf(buf, sizeof(buf), "ICECC[%d]: %s:", getpid(), argv[0]);
//.........这里部分代码省略.........
示例6: build_local
/**
* Invoke a compiler locally. This is, obviously, the alternative to
* dcc_compile_remote().
*
* The server does basically the same thing, but it doesn't call this
* routine because it wants to overlap execution of the compiler with
* copying the input from the network.
*
* This routine used to exec() the compiler in place of distcc. That
* is slightly more efficient, because it avoids the need to create,
* schedule, etc another process. The problem is that in that case we
* can't clean up our temporary files, and (not so important) we can't
* log our resource usage.
*
**/
int build_local(CompileJob &job, MsgChannel *local_daemon, struct rusage *used)
{
list<string> arguments;
string compiler_name = find_compiler(job);
if (compiler_name.empty()) {
log_error() << "could not find " << job.compilerName() << " in PATH." << endl;
return EXIT_NO_SUCH_FILE;
}
arguments.push_back(compiler_name);
appendList(arguments, job.allFlags());
if (job.dwarfFissionEnabled()) {
arguments.push_back("-gsplit-dwarf");
}
if (!job.inputFile().empty()) {
arguments.push_back(job.inputFile());
}
if (!job.outputFile().empty()) {
arguments.push_back("-o");
arguments.push_back(job.outputFile());
}
vector<char*> argv;
string argstxt;
for (list<string>::const_iterator it = arguments.begin(); it != arguments.end(); ++it) {
argv.push_back(strdup(it->c_str()));
argstxt += ' ';
argstxt += *it;
}
argv.push_back(0);
trace() << "invoking:" << argstxt << endl;
if (!local_daemon) {
int fd;
if (!dcc_lock_host(fd)) {
log_error() << "can't lock for local job" << endl;
return EXIT_DISTCC_FAILED;
}
lock_fd = fd;
}
bool color_output = job.language() != CompileJob::Lang_Custom
&& colorify_wanted(job);
int pf[2];
if (color_output && pipe(pf)) {
color_output = false;
}
if (used || color_output) {
flush_debug();
child_pid = fork();
}
if (child_pid == -1){
log_perror("fork failed");
}
if (!child_pid) {
dcc_increment_safeguard(job.language() == CompileJob::Lang_Custom ? SafeguardStepCustom : SafeguardStepCompiler);
if (color_output) {
if ((-1 == close(pf[0])) && (errno != EBADF)){
log_perror("close failed");
}
if ((-1 == close(2)) && (errno != EBADF)){
log_perror("close failed");
}
if (-1 == dup2(pf[1], 2)){
log_perror("dup2 failed");
}
}
execv(argv[0], &argv[0]);
int exitcode = ( errno == ENOENT ? 127 : 126 );
//.........这里部分代码省略.........
示例7: build_remote_int
//.........这里部分代码省略.........
while (waitpid(cpp_pid, &status, 0) < 0 && errno == EINTR) {}
if (shell_exit_status(status) != 0) { // failure
delete cserver;
cserver = 0;
return shell_exit_status(status);
}
} else {
int cpp_fd = open(preproc_file, O_RDONLY);
if (cpp_fd < 0) {
throw(11);
}
log_block cpp_block("write_server_cpp");
write_server_cpp(cpp_fd, cserver);
}
if (!cserver->send_msg(EndMsg())) {
log_info() << "write of end failed" << endl;
throw(12);
}
Msg *msg;
{
log_block wait_cs("wait for cs");
msg = cserver->get_msg(12 * 60);
if (!msg) {
throw(14);
}
}
check_for_failure(msg, cserver);
if (msg->type != M_COMPILE_RESULT) {
log_warning() << "waited for compile result, but got " << (char)msg->type << endl;
delete msg;
throw(13);
}
CompileResultMsg *crmsg = dynamic_cast<CompileResultMsg*>(msg);
assert(crmsg);
status = crmsg->status;
if (status && crmsg->was_out_of_memory) {
delete crmsg;
log_info() << "the server ran out of memory, recompiling locally" << endl;
throw(101);
}
if (output) {
if ((!crmsg->out.empty() || !crmsg->err.empty()) && output_needs_workaround(job)) {
delete crmsg;
log_info() << "command needs stdout/stderr workaround, recompiling locally" << endl;
throw(102);
}
write(STDOUT_FILENO, crmsg->out.c_str(), crmsg->out.size());
if (colorify_wanted(job)) {
colorify_output(crmsg->err);
} else {
write(STDERR_FILENO, crmsg->err.c_str(), crmsg->err.size());
}
if (status && (crmsg->err.length() || crmsg->out.length())) {
log_error() << "Compiled on " << hostname << endl;
}
}
delete crmsg;
assert(!job.outputFile().empty());
if (status == 0) {
receive_file(job.outputFile(), cserver);
}
} catch (int x) {
// Handle pending status messages, if any.
if(cserver) {
while(Msg* msg = cserver->get_msg(0)) {
if(msg->type == M_STATUS_TEXT)
log_error() << "Remote status (compiled on " << cserver->name << "): "
<< static_cast<StatusTextMsg*>(msg)->text << endl;
delete msg;
}
delete cserver;
cserver = 0;
}
throw(x);
}
delete cserver;
return status;
}