iNTERFACEWARE Products Manual > Installing and Using Chameleon > Language API Documentation > C++ Support > The Engine Class |
|
Looking for Iguana v.5 or v.6? Learn More or see the Help Center.
If you are using the static interface with Chameleon, your project must define an application Engine class. This class must inherit from the generated <prefix>Engine class in the stubcode package which in turn is a child of the CHMengine class. The following diagram shows the relationship. This class can be called anything that the developer chooses, typically something like HL7appEngine would be a good choice. There is no limit to the number of engine objects that can be present in an application. Sometimes it might be helpful to have one engine instance to handle ACKnowledgements, another to pre-sort incoming messages into different types, and so on. There are several steps that need to be followed to set up the Engine object:
The following code fragment shows how you would typically create an Engine object:
The Chameleon C++ framework supports the idea of a interface for logging. The parent class is CHMoutputLog. This abstraction allows any object to implement a logging interface and is explained in detail in this section of the documentation.
The stubcode Engine class has one virtual method for each message defined in the message definition file. Each function must be overridden by the user to implement the business logic required for the interface:
Each of these message virtual functions has two parameters:
The message object is a generated class which has methods for retrieving the tables that make up each message. Each table object has methods to get and set the column values in the table. These classes are described in the next section. The TransportIndex is a custom parameter that can use for any application defined purpose such as a pointer to application defined data. |