mirror of https://github.com/BOINC/boinc.git
*** empty log message ***
svn path=/trunk/boinc/; revision=10344
This commit is contained in:
parent
517ab42a14
commit
d8385571b9
|
@ -5969,3 +5969,14 @@ Rom 14 June 2006
|
||||||
|
|
||||||
lib/
|
lib/
|
||||||
diagnostics.C
|
diagnostics.C
|
||||||
|
|
||||||
|
David 14 June 2006
|
||||||
|
- core client: implement <copy_file/> property for output files
|
||||||
|
(previously it was implemented for input files only).
|
||||||
|
If present, move the file from slot directory
|
||||||
|
to project directory when the result is done.
|
||||||
|
|
||||||
|
client/
|
||||||
|
app.h
|
||||||
|
app_control.C
|
||||||
|
app_start.C
|
||||||
|
|
|
@ -199,6 +199,7 @@ public:
|
||||||
int move_trickle_file();
|
int move_trickle_file();
|
||||||
int handle_upload_files();
|
int handle_upload_files();
|
||||||
void upload_notify_app(const FILE_INFO*, const FILE_REF*);
|
void upload_notify_app(const FILE_INFO*, const FILE_REF*);
|
||||||
|
int copy_output_files();
|
||||||
|
|
||||||
int write(MIOFILE&);
|
int write(MIOFILE&);
|
||||||
int parse(MIOFILE&);
|
int parse(MIOFILE&);
|
||||||
|
|
|
@ -178,12 +178,17 @@ static void limbo_message(ACTIVE_TASK& at) {
|
||||||
//
|
//
|
||||||
#ifdef _WIN32
|
#ifdef _WIN32
|
||||||
void ACTIVE_TASK::handle_exited_app(unsigned long exit_code) {
|
void ACTIVE_TASK::handle_exited_app(unsigned long exit_code) {
|
||||||
|
#else
|
||||||
|
void ACTIVE_TASK::handle_exited_app(int stat) {
|
||||||
|
#endif
|
||||||
|
SCOPE_MSG_LOG scope_messages(log_messages, CLIENT_MSG_LOG::DEBUG_TASK);
|
||||||
get_app_status_msg();
|
get_app_status_msg();
|
||||||
get_trickle_up_msg();
|
get_trickle_up_msg();
|
||||||
result->final_cpu_time = current_cpu_time;
|
result->final_cpu_time = current_cpu_time;
|
||||||
if (task_state == PROCESS_ABORT_PENDING) {
|
if (task_state == PROCESS_ABORT_PENDING) {
|
||||||
task_state = PROCESS_ABORTED;
|
task_state = PROCESS_ABORTED;
|
||||||
} else {
|
} else {
|
||||||
|
#ifdef _WIN32
|
||||||
task_state = PROCESS_EXITED;
|
task_state = PROCESS_EXITED;
|
||||||
|
|
||||||
if (exit_code) {
|
if (exit_code) {
|
||||||
|
@ -210,28 +215,7 @@ void ACTIVE_TASK::handle_exited_app(unsigned long exit_code) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
result->exit_status = exit_code;
|
result->exit_status = exit_code;
|
||||||
}
|
|
||||||
|
|
||||||
if (app_client_shm.shm) {
|
|
||||||
detach_shmem(shm_handle, app_client_shm.shm);
|
|
||||||
app_client_shm.shm = NULL;
|
|
||||||
}
|
|
||||||
|
|
||||||
read_stderr_file();
|
|
||||||
clean_out_dir(slot_dir);
|
|
||||||
done:
|
|
||||||
gstate.request_schedule_cpus("application exited");
|
|
||||||
}
|
|
||||||
#else
|
#else
|
||||||
void ACTIVE_TASK::handle_exited_app(int stat) {
|
|
||||||
SCOPE_MSG_LOG scope_messages(log_messages, CLIENT_MSG_LOG::DEBUG_TASK);
|
|
||||||
|
|
||||||
get_app_status_msg();
|
|
||||||
get_trickle_up_msg();
|
|
||||||
result->final_cpu_time = current_cpu_time;
|
|
||||||
if (task_state == PROCESS_ABORT_PENDING) {
|
|
||||||
task_state = PROCESS_ABORTED;
|
|
||||||
} else {
|
|
||||||
if (WIFEXITED(stat)) {
|
if (WIFEXITED(stat)) {
|
||||||
task_state = PROCESS_EXITED;
|
task_state = PROCESS_EXITED;
|
||||||
result->exit_status = WEXITSTATUS(stat);
|
result->exit_status = WEXITSTATUS(stat);
|
||||||
|
@ -304,14 +288,24 @@ void ACTIVE_TASK::handle_exited_app(int stat) {
|
||||||
task_state = PROCESS_EXIT_UNKNOWN;
|
task_state = PROCESS_EXIT_UNKNOWN;
|
||||||
result->state = PROCESS_EXIT_UNKNOWN;
|
result->state = PROCESS_EXIT_UNKNOWN;
|
||||||
}
|
}
|
||||||
|
#endif
|
||||||
}
|
}
|
||||||
|
|
||||||
|
#ifdef _WIN32
|
||||||
|
if (app_client_shm.shm) {
|
||||||
|
detach_shmem(shm_handle, app_client_shm.shm);
|
||||||
|
app_client_shm.shm = NULL;
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
|
// here when task is finished for good
|
||||||
|
//
|
||||||
|
copy_output_files();
|
||||||
read_stderr_file();
|
read_stderr_file();
|
||||||
clean_out_dir(slot_dir);
|
clean_out_dir(slot_dir);
|
||||||
done:
|
done:
|
||||||
gstate.request_schedule_cpus("application exited");
|
gstate.request_schedule_cpus("application exited");
|
||||||
}
|
}
|
||||||
#endif
|
|
||||||
|
|
||||||
bool ACTIVE_TASK::finish_file_present() {
|
bool ACTIVE_TASK::finish_file_present() {
|
||||||
char path[256];
|
char path[256];
|
||||||
|
|
|
@ -272,6 +272,25 @@ static int setup_file(
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int ACTIVE_TASK::copy_output_files() {
|
||||||
|
char slotfile[256], projfile[256];
|
||||||
|
unsigned int i;
|
||||||
|
for (i=0; i<result->output_files.size(); i++) {
|
||||||
|
FILE_REF& fref = result->output_files[i];
|
||||||
|
if (!fref.copy_file) continue;
|
||||||
|
FILE_INFO* fip = fref.file_info;
|
||||||
|
sprintf(slotfile, "%s/%s", slot_dir, fref.open_name);
|
||||||
|
get_pathname(fip, projfile);
|
||||||
|
int retval = boinc_rename(slotfile, projfile);
|
||||||
|
if (retval) {
|
||||||
|
msg_printf(wup->project, MSG_ERROR,
|
||||||
|
"Can't rename output file %s", fip->name
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
// Start a task in a slot directory.
|
// Start a task in a slot directory.
|
||||||
// This includes setting up soft links,
|
// This includes setting up soft links,
|
||||||
// passing preferences, and starting the process
|
// passing preferences, and starting the process
|
||||||
|
@ -363,6 +382,7 @@ int ACTIVE_TASK::start(bool first_time) {
|
||||||
}
|
}
|
||||||
for (i=0; i<result->output_files.size(); i++) {
|
for (i=0; i<result->output_files.size(); i++) {
|
||||||
fref = result->output_files[i];
|
fref = result->output_files[i];
|
||||||
|
if (fref.copy_file) continue;
|
||||||
fip = fref.file_info;
|
fip = fref.file_info;
|
||||||
get_pathname(fref.file_info, file_path);
|
get_pathname(fref.file_info, file_path);
|
||||||
retval = setup_file(wup, fip, fref, file_path, slot_dir);
|
retval = setup_file(wup, fip, fref, file_path, slot_dir);
|
||||||
|
|
Loading…
Reference in New Issue