Jacqueline Deans 6c685d8400
Revise Documentation, Correct a single constant (#1326) (#1489)
* Fix formatting, grammar, and syntax

Additionally, a sentence that referenced something that isn't used anywhere was removed.

* Promote headers, Format stuff

Many headers were far too deep. In some cases, the highest header was h4. To correct this, the offending headers were promoted once or twice as appropriate. Minor formatting changes were made, too.

* Fixed an incorrect conversion constant.

* Update library dependency explanation

The old explanation was confusing and seemingly self contradicting in places. This new explanation aims to fix that.

Co-authored-by: Matthew Elmer <m.elmer@mailbox.org>
2023-04-21 17:32:31 -05:00

2.5 KiB

HomeDocumentation HomeSimulation Capabilities → Input Processor

This page describes the methods available in the Trick::InputProcessor class. See Input File for detailed information on the syntax of the input processor file.

User accessible routines

int shutdown()

These commands are for creating python events and manipulating them.

IPPythonEvent * new_event()
int add_read(double in_time , char * in_string)
int add_read(double in_time , char * in_string)
int delete_event(IPPythonEvent * in_event)
int manual_on(std::string name)
int manual_fire(std::string name)
int manual_off(std::string name)
int manual_done(std::string name)

The commands for setting up each event are described in Trick::IPPythonEvent

An event is in Normal mode by default, meaning its condition(s) are used to determine when to fire. Issuing one of the manual commands (manual_fire, manual_on, manual_off) puts an event in Manual mode, meaning its conditions are ignored and the type of manual command determines if the event fires. Any event can be fired once immediately with the manual_fire command; the only way to fire non-"Added" events is with manual_fire(). An event will NOT fire when the manual_off() command is issued. An event returns to Normal mode by issuing the manual_done() command. The commands described above can be done in the Run input file, and/or via the variable server, and/or via MTV (see MTV).

Event Loop

Figure IP_2 Input Processor Event Loop

The Trick process_event() job will execute the Event Loop for all events that were added with the add_event() command. For events that were added with add_event_before() or add_event_after(), the Event Loop is effectively executed once for the event immediately before/after the event target job.

Check_Conditions

Figure IP_3 Input Processor Event Check Conditions Loop

The Check Conditions Loop is called from the Event Loop to determine if the event should fire. Notice that no checking is necessary in Manual mode, the event simply fires.

Fire_Event

Figure IP_4 Input Processor Event Fire Event Loop

The Fire Event Loop is called from the Check Conditions Loop or directly by the manual_fire() command, causing all of the event's enabled actions to run.

Continue to JIT Input Processor