Alex Lin 14a75508a3 Cleaning up once include variables and copyright cleanup.
Changed all header file once include variables to follow the same naming
convention and not start with any underscores.  Also deleted old
incorrect copyright notices.  Also removed $Id: tags from all files.

Fixes #14.  Fixes #22.
2015-03-23 16:03:14 -05:00

438 lines
22 KiB
C++

#ifndef IPPYTHONEVENT_HH
#define IPPYTHONEVENT_HH
#include <string>
#include "sim_services/EventManager/include/Event.hh"
#include "sim_services/MemoryManager/include/reference.h"
#include "sim_services/SimObject/include/JobData.hh"
#ifdef SWIG
// SWIG macros are not normally run on classes in sim_services. We can add the the processed code manually
%trick_swig_class_typemap(Trick::IPPythonEvent, Trick__IPPythonEvent)
#endif
namespace Trick {
class IPPython ;
class MTV ;
/** Data associated with each event condition.\n */
struct condition_t {
condition_t() ;
/** True means condition is to be evaluated during event processing.\n */
char enabled ; /**< trick_io(*io) trick_units(--) */
/** True means that when fired, condition stays fired.\n */
char hold ; /**< trick_io(*io) trick_units(--) */
/** True when the condition evaluated to true.\n */
char fired ; /**< trick_io(*io) trick_units(--) */
/** Count of how many times this condition fired.\n */
int fired_count ; /**< trick_io(*io) trick_units(--) */
/** Last simulation time this condition fired.\n */
double fired_time ; /**< trick_io(*io) trick_units(s) */
/** The string containing condition to be evaluated.\n */
std::string str; /**< trick_io(*io) trick_units(--) */
/** Optional comment provided by user to display in mtv.\n */
std::string comment; /**< trick_io(*io) trick_units(--) */
/** Variable reference to a model variable to be used for condition.\n */
REF2 * ref ; /**< trick_io(**) trick_units(--) */
/** Job pointer to a model job to be used for condition.\n */
Trick::JobData * job ; /**< trick_io(**) trick_units(--) */
/** Type of condition string: 0=python, 1=variable, 2=job.\n */
int cond_type ; /**< trick_io(*io) trick_units(--) */
} ;
/** Data associated with each event action.\n */
struct action_t {
action_t() ;
/** True means action is to be run when fired.\n */
char enabled ; /**< trick_io(*io) trick_units(--) */
/** True when the action was run.\n */
char ran ; /**< trick_io(*io) trick_units(--) */
/** Count how many times this action has been run.\n */
int ran_count ; /**< trick_io(*io) trick_units(--) */
/** Last simulation time this action ran.\n */
double ran_time ; /**< trick_io(*io) trick_units(s) */
/** The string containing action to be run.\n */
std::string str; /**< trick_io(*io) trick_units(--) */
/** Optional comment provided by user to display in mtv.\n */
std::string comment; /**< trick_io(*io) trick_units(--) */
/** Job pointer to a model job to run as the action.\n */
JobData * job ; /**< trick_io(**) trick_units(--) */
/** Type of action string: 0=python, 1=job ON, 2=job OFF 3=job call.\n */
int act_type ; /**< trick_io(*io) trick_units(--) */
} ;
/**
This class provides python input file event capability.
@author Alex Lin, Danny Strauss
*/
class IPPythonEvent : public Trick::Event {
TRICK_MM_FRIENDS(Trick__IPPythonEvent)
public:
/** True when event is in the event_list to be processed; false when it is to be removed from event_list.\n */
bool added ; /**< trick_io(*io) trick_units(--) */
/** True for a user input event, false for a read or other trick event.\n */
bool is_user_event ; /**< trick_io(*io) trick_units(--) */
/** @userdesc True when user issues a manual command, normal condition evaluation is overriden.\n */
bool manual ; /**< trick_io(*io) trick_units(--) */
/** @userdesc True when event fired because of a manual_on or manual_fire command.\n */
bool manual_fired ; /**< trick_io(*io) trick_units(--) */
/** Toggle to turn on/off event info messages (e.g., when an event fires).\n */
static bool info_msg ; /**< trick_io(**) trick_units(--) */
/** True when ALL conditions must be true to make action(s) run; default is false.\n */
bool cond_all ; /**< trick_io(*io) trick_units(--) */
/** @userdesc True when event conditions setup was evaluated as true.\n */
char fired ; /**< trick_io(*io) trick_units(--) */
/** True when an event condition fired and its hold is true, also used for manual mode hold.\n */
char hold ; /**< trick_io(*io) trick_units(--) */
/** @userdesc True when any event action was run.\n */
char ran ; /**< trick_io(*io) trick_units(--) */
/** Count of how many conditions this event has.\n */
int condition_count ; /**< trick_io(*io) trick_units(--) */
/** @userdesc Count of how many times this event has fired.\n */
int fired_count ; /**< trick_io(*io) trick_units(--) */
/** @userdesc Last simulation time that this event fired.\n */
double fired_time ; /**< trick_io(*io) trick_units(s) */
/** Count of how many actions this event has.\n */
int action_count ; /**< trick_io(*io) trick_units(--) */
/** @userdesc Count of how many times this event has run its actions.\n */
int ran_count ; /**< trick_io(*io) trick_units(--) */
/** @userdesc Last simulation time that this event ran an action.\n */
double ran_time ; /**< trick_io(*io) trick_units(s) */
/** Array of event's conditions.\n */
condition_t * cond ; /**< trick_io(*io) trick_units(--) */
/** Array of event's actions.\n */
action_t * act ; /**< trick_io(*io) trick_units(--) */
/**
@brief Constructor.
*/
IPPythonEvent() ;
virtual ~IPPythonEvent() ;
/**
@brief @userdesc Command to make event evaluation require that ALL of event's conditions be true to make action(s) run.
@par Python Usage:
@code <event_object>.condition_all() @endcode
@return always 0
*/
int condition_all() ;
/**
@brief @userdesc Command to make event evaluation require that ANY of event's conditions be true to make action(s) run (this is the default).
@par Python Usage:
@code <event_object>.condition_any() @endcode
@return always 0
*/
int condition_any() ;
/**
@brief @userdesc Command to manually fire the event next cycle and hold it fired (enter manual mode, bypasses normal condition processing).
@par Python Usage:
@code <event_object>.manual_on() @endcode
*/
virtual void manual_on() ;
/**
@brief @userdesc Command to manually fire the event once NOW (enter manual mode, bypasses normal condition processing).
@par Python Usage:
@code <event_object>.manual_fire() @endcode
*/
virtual void manual_fire() ;
/**
@brief @userdesc Command to manually set the event as not fired (enter manual mode, bypasses normal condition processing).
@par Python Usage:
@code <event_object>.manual_off() @endcode
*/
virtual void manual_off() ;
/**
@brief @userdesc Command to return to normal event processing (needed to end manual mode after any manual commands).
@par Python Usage:
@code <event_object>.manual_done() @endcode
*/
virtual void manual_done() ;
/**
@brief @userdesc Command to turn on event info messages (e.g., get a message each time an event fires).
Event info messages will be published using the Trick status message system.
@par Python Usage:
@code trick.set_event_info_msg_on() @endcode
@return always 0
*/
static void set_event_info_msg_on() ;
/**
@brief @userdesc Command to turn off event info messages (off is the default).
No event info messages will be published using the Trick status message system.
@par Python Usage:
@code trick.set_event_info_msg_off() @endcode
@return always 0
*/
static void set_event_info_msg_off() ;
/**
@brief called by the event manager when the event is loaded from a checkpoint
*/
virtual void restart() ;
/**
@brief @userdesc Command to create a new condition and set its input string (or reset an existing condition string), num is index starting at 0.
@par Python Usage:
@code <event_object>.condition(<num>, """<str>""") @endcode
@param num - number identifying the condition, starting at 0 for the 1st condition, 1 for the 2nd, etc.
@param str - the condition input boolean expression, using Python syntax, to be evaluated each cycle
@param comment - optional description to be displayed in mtv (defaults to 1st 50 characters of str)
@param ref - optional reference to a model variable to be used for the condition (this parameter for internal use only!)
@param job - optional pointer to job to be called as the condition (this parameter for internal use only!)
@return always 0
*/
int condition(int num, std::string str, std::string comment="", REF2* ref=NULL, JobData* job=NULL) ;
/**
@brief @userdesc Command to create a new condition using a boolean model variable (or reset an existing condition variable), num is index starting at 0.
Using a model variable is more optimal than a normal condition() because there is no Python string to parse.
@par Python Usage:
@code <event_object>.condition_var(<num>, """<varname>""") @endcode
@param num - number identifying the condition, starting at 0 for the 1st condition, 1 for the 2nd, etc.
@param varname - the name of the boolean model variable, to be evaluated each cycle
@param comment - optional description to be displayed in mtv (defaults to 1st 50 characters of str)
@return always 0
*/
int condition_var(int num, std::string varname, std::string comment="") ;
/**
@brief @userdesc Command to create a new condition using a model job return val (or reset an existing condition job), num is index starting at 0.
Using a model job return value is more optimal than a normal condition() because there is no Python string to parse.
@par Python Usage:
@code <event_object>.condition_job(<num>, """<jobname>""") @endcode
@param num - number identifying the condition, starting at 0 for the 1st condition, 1 for the 2nd, etc.
@param jobname - the name of the model job, to be called and evaluated each cycle
@param comment - optional description to be displayed in mtv (defaults to 1st 50 characters of str)
@return always 0
*/
int condition_job(int num, std::string jobname, std::string comment="") ;
/**
@brief @userdesc Command to set an existing condition to hold, so that when it fires it stays in the fired state.
@par Python Usage:
@code <event_object>.condition_hold_on(<num>) @endcode
@param num - number identifying the condition
@return always 0
*/
int condition_hold_on(int num) ;
/**
@brief @userdesc Command to set an existing condition to not hold its fired state (default).
@par Python Usage:
@code <event_object>.condition_hold_off(<num>) @endcode
@param num - number identifying the condition
@return always 0
*/
int condition_hold_off(int num) ;
/**
@brief @userdesc Command to enable an existing condition (default is enabled) so that it is evaluated during event processing.
@par Python Usage:
@code <event_object>.condition_enable(<num>) @endcode
@param num - number identifying the condition
@return always 0
*/
int condition_enable(int num) ;
/**
@brief @userdesc Command to disable an existing condition so that it is not evaluated during event processing.
@par Python Usage:
@code <event_object>.condition_disable(<num>) @endcode
@param num -number identifying the condition
@return always 0
*/
int condition_disable(int num) ;
/**
@brief @userdesc Accessor function to test if the condition, indicated by num, fired (is currently in the fired state).
@par Python Usage:
@code <my_bool> = <event_object>.condition_fired(<num>) @endcode
@param num - number identifying the condition
@return true if the specified condition fired in the most recent cycle that the event was evaluated
*/
bool condition_fired(int num) ;
/**
@brief @userdesc Accessor function to see how many times the condition, indicated by num, fired.
@par Python Usage:
@code <my_int> = <event_object>.condition_fired_count<(num>) @endcode
@param num - number identifying the condition
@return number of times the specified condition has fired
*/
int condition_fired_count(int num) ;
/**
@brief @userdesc Accessor function to see when was the last time the condition, indicated by num, fired.
@par Python Usage:
@code <my_double> = <event_object>.condition_fired_time(<num>) @endcode
@param num - number identifying the condition
@return the last simulation time that this condition fired (-1.0 if never fired)
*/
double condition_fired_time(int num) ;
/**
@brief @userdesc Accessor function to return the condition string, indicated by num.
@par Python Usage:
@code <my_string> = <event_object>.condition(<num>) @endcode
@param num - number identifying the condition
@return the specified condition's input boolean expression
*/
std::string condition_string(int num) ;
/**
@brief @userdesc Command to create a new action and set its input string (or reset an existing action string), num is index starting at 0.
@par Python Usage:
@code <event_object>.action(<num>, """<str>""") @endcode
@param num - number identifying the action, starting at 0 for the 1st action, 1 for the 2nd, etc.
@param str - the action input statement(s), using Python syntax, to be run (processed) when this event is fired
@param comment - optional description to be displayed in mtv (defaults to 1st 50 characters of str)
@param job - optional pointer to job to be called in the action (this parameter for internal use only!)
@param act_type - optional type of action string: 0=python 1=Job ON, 2=Job OFF, 3=Job Call (this parameter for internal use only!)
@return always 0
*/
int action(int num, std::string str, std::string comment="", JobData* job=NULL, int act_type=0) ;
/**
@brief @userdesc Command to create a new action using a model job (or reset an existing action job), num is index starting at 0.
Using a model job is more optimal than a normal action() because there is no Python string to parse.
@par Python Usage:
@code <event_object>.action_job(<num>, """<jobname>""") @endcode
@param num - number identifying the action, starting at 0 for the 1st action, 1 for the 2nd, etc.
@param jobname - the action job name of the job to be called when this event is fired
@param comment - optional description to be displayed in mtv (defaults to 1st 50 characters of str)
@return always 0
*/
int action_job(int num, std::string jobname, std::string comment="") ;
/**
@brief @userdesc Command to create a new action to turn a model job ON, num is index starting at 0.
@par Python Usage:
@code <event_object>.action_job_on(<num>, """<jobname>""") @endcode
@param num - number identifying the action, starting at 0 for the 1st action, 1 for the 2nd, etc.
@param jobname - the action job name of the job to enable when this event is fired
@param comment - optional description to be displayed in mtv (defaults to 1st 50 characters of str)
@return always 0
*/
int action_job_on(int num, std::string jobname, std::string comment="") ;
/**
@brief @userdesc Command to create a new action to turn a model job OFF, num is index starting at 0.
@par Python Usage:
@code <event_object>.action_job_off(<num>, """<jobname>""") @endcode
@param num - number identifying the action, starting at 0 for the 1st action, 1 for the 2nd, etc.
@param jobname - the action job name of the job to disable when this event is fired
@param comment - optional description to be displayed in mtv (defaults to 1st 50 characters of str)
@return always 0
*/
int action_job_off(int num, std::string jobname, std::string comment="") ;
/**
@brief @userdesc Command to enable an existing action (default is enabled) so that it is run when fired during event processing.
@par Python Usage:
@code <event_object>.action_enable(<num>) @endcode
@param num - number identifying the action
@return always 0
*/
int action_enable(int num) ;
/**
@brief @userdesc Command to disable an existing action so that it is not run when fired during event processing.
@par Python Usage:
@code <event_object>.action_disable(<num>) @endcode
@param num - number identifying the action
@return always 0
*/
int action_disable(int num) ;
/**
@brief @userdesc Accessor function to test if the action, indicated by num, ran.
@par Python Usage:
@code <my_bool> = <event_object>.action_ran(<num>) @endcode
@param num - number identifying the action
@return true if the specified action ran at least once
*/
bool action_ran(int num) ;
/**
@brief @userdesc Accessor function to see how many times the action, indicated by num, ran.
@par Python Usage:
@code <my_int> = <event_object>.action_ran_count(<num>) @endcode
@param num - number identifying the action
@return number of times the specified action ran
*/
int action_ran_count(int num) ;
/**
@brief @userdesc Accessor function to see when was the last time the action, indicated by num, ran.
@par Python Usage:
@code <my_double> = <event_object>.action_ran_time(<num>) @endcode
@param num - number identifying the action
@return the last simulation time that this action ran (-1.0 if never ran)
*/
double action_ran_time(int num) ;
virtual int process( long long curr_time ) ;
bool process_user_event( long long curr_time ) ;
virtual void add() ;
virtual void remove() ;
/* A static method that allows us to set the IPPython * from the S_define sim_object level without
any events instantiated yet */
static void set_python_processor(Trick::IPPython * in_ip) ;
static void set_mtv(Trick::MTV * in_mtv) ;
private:
/* A static pointer to the python input processor set at the S_define level */
static Trick::IPPython * ip ;
/* A static pointer to the MTV set at the S_define level */
static Trick::MTV * mtv ;
} ;
}
Trick::IPPythonEvent * ippython_new_event(std::string event_name = "" ) ;
int ippython_delete_event(Trick::IPPythonEvent * in_event) ;
int ippython_add_event(Trick::IPPythonEvent * in_event) ;
int ippython_add_event_before( Trick::IPPythonEvent * in_event, std::string target_name, unsigned int target_inst = 1) ;
int ippython_add_event_after( Trick::IPPythonEvent * in_event, std::string target_name, unsigned int target_inst = 1) ;
int ippython_add_read( unsigned int thread_id , double in_time , char * in_string ) ;
int ippython_add_read( double in_time , char * in_string ) ;
int ippython_manual_on(std::string event_name) ;
int ippython_manual_fire(std::string event_name) ;
int ippython_manual_off(std::string event_name) ;
int ippython_manual_done(std::string event_name) ;
#ifdef SWIG
// SWIG macros are not normally run on classes in sim_services. We can add the the processed code manually
%trick_cast_as(Trick::IPPythonEvent, Trick__IPPythonEvent)
#endif
#endif