mirror of
https://github.com/nasa/trick.git
synced 2025-01-26 06:09:18 +00:00
246 lines
5.6 KiB
C++
246 lines
5.6 KiB
C++
|
|
#include <math.h>
|
|
|
|
#include "trick/JobData.hh"
|
|
#include "trick/SimObject.hh"
|
|
|
|
long long Trick::JobData::time_tic_value = 0 ;
|
|
|
|
Trick::JobData::JobData() {
|
|
|
|
/** @par Detailed Design */
|
|
|
|
/** @li initializes the job as enabled with 0 cycle rate. */
|
|
disabled = false ;
|
|
handled = false ;
|
|
thread = 0 ;
|
|
id = 0 ;
|
|
sim_object_id = -1 ;
|
|
job_class = -1 ;
|
|
sup_class_data = NULL ;
|
|
cycle = 0.0 ;
|
|
start = 0.0 ;
|
|
stop = 0.0 ;
|
|
complete = false ;
|
|
rt_start_time = -1;
|
|
phase = 60000 ;
|
|
system_job_class = 0 ;
|
|
|
|
cycle_tics = 0 ;
|
|
start_tics = 0 ;
|
|
stop_tics = 0 ;
|
|
next_tics = 0 ;
|
|
|
|
frame_time = 0 ;
|
|
frame_time_seconds = 0.0;
|
|
}
|
|
|
|
Trick::JobData::JobData(int in_thread, int in_id, std::string in_job_class_name , void* in_sup_class_data,
|
|
double in_cycle, std::string in_name, std::string in_tag, int in_phase,
|
|
double in_start, double in_stop) {
|
|
|
|
/** @par Detailed Design */
|
|
|
|
/** @li initializes the job according to arguments */
|
|
disabled = false ;
|
|
handled = false ;
|
|
thread = in_thread ;
|
|
id = in_id ;
|
|
sim_object_id = -1 ;
|
|
job_class = -1 ;
|
|
job_class_name = in_job_class_name ;
|
|
sup_class_data = in_sup_class_data ;
|
|
cycle = in_cycle ;
|
|
start = in_start ;
|
|
stop = in_stop ;
|
|
complete = false ;
|
|
name = in_name ;
|
|
add_tag(in_tag) ;
|
|
rt_start_time = -1;
|
|
phase = in_phase ;
|
|
system_job_class = 0 ;
|
|
|
|
cycle_tics = 0 ;
|
|
start_tics = 0 ;
|
|
stop_tics = 0 ;
|
|
next_tics = 0 ;
|
|
|
|
frame_time = 0 ;
|
|
frame_time_seconds = 0.0 ;
|
|
}
|
|
|
|
void Trick::JobData::enable() {
|
|
disabled = false ;
|
|
}
|
|
|
|
void Trick::JobData::disable() {
|
|
disabled = true ;
|
|
}
|
|
|
|
bool Trick::JobData::get_handled() {
|
|
return(handled) ;
|
|
}
|
|
|
|
int Trick::JobData::set_handled(bool yes_no) {
|
|
handled = yes_no ;
|
|
return(0) ;
|
|
}
|
|
|
|
int Trick::JobData::set_time_tic_value(long long in_time_tic_value) {
|
|
time_tic_value = in_time_tic_value ;
|
|
return 0 ;
|
|
}
|
|
|
|
int Trick::JobData::set_cycle(double in_cycle) {
|
|
cycle = in_cycle ;
|
|
calc_cycle_tics() ;
|
|
return 0 ;
|
|
}
|
|
|
|
int Trick::JobData::calc_cycle_tics() {
|
|
cycle_tics = (long long)round(cycle * time_tic_value) ;
|
|
return 0 ;
|
|
}
|
|
|
|
int Trick::JobData::set_next_call_time(long long time_tics) {
|
|
if ( next_tics > time_tics ) {
|
|
next_tics = time_tics - ( time_tics % cycle_tics ) + cycle_tics ;
|
|
} else {
|
|
next_tics = time_tics ;
|
|
}
|
|
return 0 ;
|
|
}
|
|
|
|
|
|
int Trick::JobData::set_system_job_class(bool yes_no) {
|
|
system_job_class = yes_no ;
|
|
return(0) ;
|
|
}
|
|
|
|
int Trick::JobData::add_tag( std::string in_tag ) {
|
|
if ( ! in_tag.empty() ) {
|
|
tags.insert(in_tag) ;
|
|
}
|
|
return(0) ;
|
|
}
|
|
|
|
int Trick::JobData::add_depend( JobData * depend_job ) {
|
|
depends.push_back(depend_job) ;
|
|
return(0) ;
|
|
}
|
|
|
|
int Trick::JobData::add_inst_before( InstrumentBase * in_job ) {
|
|
std::vector<Trick::InstrumentBase*>::size_type ii ;
|
|
for ( ii = 0 ; ii < inst_before.size() ; ++ii ) {
|
|
if ( in_job->phase < inst_before[ii]->phase ) {
|
|
break ;
|
|
}
|
|
}
|
|
inst_before.insert( inst_before.begin() + ii, in_job ) ;
|
|
return 0 ;
|
|
}
|
|
|
|
int Trick::JobData::add_inst_after( InstrumentBase * in_job ) {
|
|
std::vector<Trick::InstrumentBase*>::size_type ii ;
|
|
for ( ii = 0 ; ii < inst_after.size() ; ++ii ) {
|
|
if ( in_job->phase < inst_after[ii]->phase ) {
|
|
break ;
|
|
}
|
|
}
|
|
inst_after.insert( inst_after.begin() + ii, in_job ) ;
|
|
return 0 ;
|
|
}
|
|
|
|
int Trick::JobData::remove_inst( std::string job_name ) {
|
|
int ii , size ;
|
|
|
|
size = inst_before.size() ;
|
|
for ( ii = size - 1 ; ii >= 0 ; ii-- ) {
|
|
if ( ! inst_before[ii]->name.compare(job_name) ) {
|
|
inst_before.erase( inst_before.begin() + ii ) ;
|
|
}
|
|
}
|
|
|
|
size = inst_after.size() ;
|
|
for ( ii = size - 1 ; ii >= 0 ; ii-- ) {
|
|
if ( ! inst_after[ii]->name.compare(job_name) ) {
|
|
inst_after.erase( inst_after.begin() + ii ) ;
|
|
}
|
|
}
|
|
return 0 ;
|
|
}
|
|
|
|
int Trick::JobData::call() {
|
|
int ret ;
|
|
unsigned int ii , size ;
|
|
InstrumentBase * curr_job ;
|
|
|
|
size = inst_before.size() ;
|
|
for ( ii = 0 ; ii < size ; ii++ ) {
|
|
curr_job = inst_before[ii] ;
|
|
curr_job->call() ;
|
|
}
|
|
|
|
ret = parent_object->call_function(this) ;
|
|
|
|
size = inst_after.size() ;
|
|
for ( ii = 0 ; ii < size ; ii++ ) {
|
|
curr_job = inst_after[ii] ;
|
|
curr_job->call() ;
|
|
}
|
|
|
|
return ret ;
|
|
}
|
|
|
|
double Trick::JobData::call_double() {
|
|
double ret ;
|
|
unsigned int ii , size ;
|
|
InstrumentBase * curr_job ;
|
|
|
|
size = inst_before.size() ;
|
|
for ( ii = 0 ; ii < size ; ii++ ) {
|
|
curr_job = inst_before[ii] ;
|
|
curr_job->call() ;
|
|
}
|
|
|
|
ret = parent_object->call_function_double(this) ;
|
|
|
|
size = inst_after.size() ;
|
|
for ( ii = 0 ; ii < size ; ii++ ) {
|
|
curr_job = inst_after[ii] ;
|
|
curr_job->call() ;
|
|
}
|
|
|
|
return ret ;
|
|
}
|
|
|
|
int Trick::JobData::copy_from_checkpoint( JobData * in_job ) {
|
|
|
|
/** @par Detailed Design */
|
|
|
|
/** @li resets the current job disabled, cycle rate, and job class name and phase from
|
|
incoming job data */
|
|
|
|
disabled = in_job->disabled ;
|
|
complete = in_job->complete ;
|
|
|
|
handled = in_job->handled ;
|
|
|
|
cycle = in_job->cycle ;
|
|
start = in_job->start ;
|
|
stop = in_job->stop ;
|
|
|
|
job_class_name = in_job->job_class_name ;
|
|
phase = in_job->phase ;
|
|
system_job_class = in_job->system_job_class ;
|
|
|
|
thread = in_job->thread ;
|
|
|
|
cycle_tics = in_job->cycle_tics ;
|
|
start_tics = in_job->start_tics ;
|
|
stop_tics = in_job->stop_tics ;
|
|
next_tics = in_job->next_tics ;
|
|
|
|
return(0) ;
|
|
}
|