2015-02-26 09:02:31 -06:00
|
|
|
|
|
|
|
#include <iostream>
|
|
|
|
#include <sys/resource.h>
|
2015-06-01 10:28:29 -05:00
|
|
|
#include "trick/Executive.hh"
|
2015-06-02 08:29:34 -05:00
|
|
|
#include "trick/ExecutiveException.hh"
|
2019-06-14 09:04:20 -05:00
|
|
|
#include "trick/clock_proto.h"
|
2015-02-26 09:02:31 -06:00
|
|
|
|
|
|
|
/**
|
|
|
|
@details
|
|
|
|
-# Call the initialization jobs.
|
|
|
|
-# The scheduler will immediately return if the initialization job returns a
|
|
|
|
non-zero return code. The return code of the initialization job will be
|
|
|
|
returned from Trick::Executive::init().
|
|
|
|
-# If no execption is thrown return 0
|
|
|
|
*/
|
2019-06-18 10:34:56 -05:00
|
|
|
int Trick::Executive::call_initialization() {
|
2015-02-26 09:02:31 -06:00
|
|
|
|
|
|
|
int ret = 0 ;
|
|
|
|
|
|
|
|
except_file = "in intialization queue" ;
|
|
|
|
|
|
|
|
/* Call the initialization jobs. */
|
|
|
|
initialization_queue.reset_curr_index() ;
|
|
|
|
while ( (curr_job = initialization_queue.get_next_job()) != NULL ) {
|
2019-06-14 09:04:20 -05:00
|
|
|
long long start = clock_wall_time();
|
2015-02-26 09:02:31 -06:00
|
|
|
ret = curr_job->call() ;
|
2019-06-14 09:04:20 -05:00
|
|
|
long long end = clock_wall_time();
|
2019-06-18 10:34:56 -05:00
|
|
|
if(init_log_stream.is_open()) {
|
2019-06-14 09:04:20 -05:00
|
|
|
init_log_stream << "init," << curr_job->name << ',' << (double)(end-start)/clock_tics_per_sec() << '\n';
|
|
|
|
}
|
2015-02-26 09:02:31 -06:00
|
|
|
if ( ret != 0 ) {
|
2015-06-02 08:29:34 -05:00
|
|
|
throw Trick::ExecutiveException(ret , curr_job->name.c_str() , 0 , "initialization job did not return 0") ;
|
2015-02-26 09:02:31 -06:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/* return 0 if there are no errors. */
|
|
|
|
return ret ;
|
|
|
|
}
|