Apama
10.15.3.4
|
External (client-visible) interface to Transport Integration Layer (TIL) plugin libraries within the Apama Integration Adapter Framework (IAF). More...
#include <AP_Types.h>
#include <IAF_Platform.h>
#include <EventCodec.h>
#include <AP_TimestampSet.h>
#include <IAF_TimestampConfig.h>
Go to the source code of this file.
Macros | |
#define | AP_EVENTTRANSPORT_VERSION 0x00040000 |
Transport API version. More... | |
Typedefs | |
typedef AP_EVENTTRANSPORT_API void(AP_EVENTTRANSPORT_CALL * | AP_EventTransportInfoPtr) (AP_uint32 *version, AP_uint32 *capabilities) |
AP_EventTransportInfoPtr. More... | |
typedef AP_EVENTTRANSPORT_API AP_EventTransport *(AP_EVENTTRANSPORT_CALL * | AP_EventTransportCtorPtr) (AP_char8 *name, AP_EventTransportProperties *properties, AP_EventTransportError *err, AP_char8 **errMsg, IAF_TimestampConfig *timestampConfig) |
AP_EventTransportCtorPtr. More... | |
typedef AP_EVENTTRANSPORT_API void(AP_EVENTTRANSPORT_CALL * | AP_EventTransportDtorPtr) (AP_EventTransport *obj) |
AP_EventTransportDtorPtr. More... | |
Enumerations | |
enum | AP_EventTransportError { AP_EventTransport_OK = 0, AP_EventTransport_InternalError, AP_EventTransport_TransportFailure, AP_EventTransport_DecodingFailure, AP_EventTransport_BadProperties, AP_EventTransport_CantStart } |
AP_EventTransportError. More... | |
External (client-visible) interface to Transport Integration Layer (TIL) plugin libraries within the Apama Integration Adapter Framework (IAF).
This is the interface that must be implemented by all transport libraries in order to be successfully loaded and integrated by the IAF.
#define AP_EVENTTRANSPORT_VERSION 0x00040000 |
Transport API version.
The upper 16 bits identify the major release of the API; the lower 16 bits indicate minor versions within that release. No changes that break backward binary compatibility will be made within a given major release of the API. That is, minor releases may add functionality and fix bugs, but will not change or remove any documented behaviour.
Version history: 1.0 First public version, released with Apama 2.2.0 1.1 Add versioning and multiple transport support for Apama 2.2.1 2.0 Force users to rebuild for VS7.1 2.1 Fixes for 3.0 to correct bug 5063 4.0 Addition of high-accuracy timestamps for latency measurement.
typedef AP_EVENTTRANSPORT_API AP_EventTransport*(AP_EVENTTRANSPORT_CALL* AP_EventTransportCtorPtr) (AP_char8 *name, AP_EventTransportProperties *properties, AP_EventTransportError *err, AP_char8 **errMsg, IAF_TimestampConfig *timestampConfig) |
AP_EventTransportCtorPtr.
Pointer to the constructor function for the transport library. Each TIL plugin library must export a function with this signature, named using the AP_EVENTTRANSPORT_CTOR_FUNCTION_NAME macro.
Constructs a new instance of the event transport. This function will be called by the adapter main program when the adapter starts up. The transport should be created in a 'stopped' state, such that it is not actively processing data from the external transport. A call to the start() function is required to begin processing.
Note that the input parameters (name, properties, timestampConfig) are owned by the caller. The IAF framework guarantees that propertes and timestampConfig will remain valid until after a subsequent call to updateProperties(), so it is safe to hold a pointer to this structure. You should, however, copy the name string if you wish to keep it. The contents of the output parameter errMsg belongs to the transport.
name | The name of this transport instance |
properties | Transport property set derived from the IAF config file |
err | 'Out' parameter for error code if constructor fails |
errMsg | 'Out' parameter for error message if constructor fails |
timestampConfig | Timestamp recording/logging settings |
typedef AP_EVENTTRANSPORT_API void(AP_EVENTTRANSPORT_CALL* AP_EventTransportDtorPtr) (AP_EventTransport *obj) |
AP_EventTransportDtorPtr.
Pointer to the destructor function for the transport library. Each TIL plugin library must export a function with this signature, named using the AP_EVENTTRANSPORT_DTOR_FUNCTION_NAME macro.
Destroys an instance of the event transport that was previously created by AP_EventTransport_ctor. The transport may assume that it has been stopped and flushed before the destructor is called.
transport | The event transport object to be destroyed |
typedef AP_EVENTTRANSPORT_API void(AP_EVENTTRANSPORT_CALL* AP_EventTransportInfoPtr) (AP_uint32 *version, AP_uint32 *capabilities) |
AP_EventTransportInfoPtr.
Pointer to the info function for the tranport library. Each transport plugin library must export a function with this signature, named using the AP_EVENTTRANSPORT_INFO_FUNCTION_NAME macro.
Returns basic information about the transports implemented by this shared library, along with the transport API version it was built against.
version | 'Out' parameter for version number of transport library. This should be the value of AP_EVENTTRANSPORT_VERSION that was defined in EventTransport.h when the transport was built. The IAF will check the version number to ensure that it can support all the capabilities offered by the transport |
capabilities | 'Out' parameter for the capabilities of the transports provided by this library. Currently no such capabilities are defined, so the value of this field will be ignored by the IAF. However, all bits of the capabilities value are reserved for future use, so current transports should ensure that they set this value to zero. |
AP_EventTransportError.
Error codes that can be returned by transport library functions. The enumeration values follow the normal UNIX convention of zero == OK and non-zero == error.