Babeltrace 2 C API 2.1.0
Open-source trace manipulation framework
|
Trace event.
An event represents a trace event record.
An event is an instance of an event class:
In the illustration above, notice that:
Borrow the class of an event with bt_event_borrow_class() and bt_event_borrow_class_const().
An event is a trace IR data object.
You cannot directly create an event: there's no bt_event_create()
function. The Babeltrace 2 library creates an event within an event message from an event class. Therefore, to fill the fields of an event, you must first borrow the event from an event message with bt_message_event_borrow_event().
An event is a unique object: it belongs to an event message.
Some library functions freeze events on success. The documentation of those functions indicate this postcondition.
The type of an event is bt_event.
An event conceptually belongs to a stream. Borrow the stream of an event with bt_event_borrow_stream() and bt_event_borrow_stream_const().
If the stream class of the event supports packets, then the event also belongs to a packet. In that case, borrow the packet of an event with bt_event_borrow_packet() and bt_event_borrow_packet_const().
Because a stream or a packet could contain millions of events, there are no actual links from a stream or from a packet to its events.
An event has the following properties:
Payload field of the event.
The payload of an event contains its main trace data.
The class of the payload field of an event is set at the level of the class of the event. See bt_event_class_set_payload_field_class(), bt_event_class_borrow_payload_field_class(), and bt_event_class_borrow_payload_field_class_const().
Use bt_event_borrow_payload_field() and bt_event_borrow_payload_field_const().
Specific context field of the event.
The specific context of an event contains any contextual data of which the layout is specific to the class of the event and which doesn't belong to the payload.
The class of the specific context field of an event is set at the level of the class of the event. See bt_event_class_set_specific_context_field_class() bt_event_class_borrow_specific_context_field_class(), and bt_event_class_borrow_specific_context_field_class_const()
Use bt_event_borrow_specific_context_field() and bt_event_borrow_specific_context_field_const().
Common context field of the event.
The common context of an event contains contextual data of which the layout is common to all the event classes of the stream class of the event.
The class of the common context field of an event is set at the level of the stream class of the event. See bt_stream_class_set_event_common_context_field_class() bt_stream_class_borrow_event_common_context_field_class(), and bt_stream_class_borrow_event_common_context_field_class_const().
Use bt_event_borrow_common_context_field() and bt_event_borrow_common_context_field_const().
Class access | |
bt_event_class * | bt_event_borrow_class (bt_event *event) |
Borrows the class of the event event. | |
const bt_event_class * | bt_event_borrow_class_const (const bt_event *event) |
Borrows the class of the event event (const version). | |
Stream access | |
bt_stream * | bt_event_borrow_stream (bt_event *event) |
Borrows the stream conceptually containing the event event. | |
const bt_stream * | bt_event_borrow_stream_const (const bt_event *event) |
Borrows the stream conceptually containing the event event (const version). | |
Packet access | |
bt_packet * | bt_event_borrow_packet (bt_event *event) |
Borrows the packet conceptually containing the event event. | |
const bt_packet * | bt_event_borrow_packet_const (const bt_event *event) |
Borrows the packet conceptually containing the event event (const version). | |
Properties | |
bt_field * | bt_event_borrow_payload_field (bt_event *event) |
Borrows the payload field of the event event. | |
const bt_field * | bt_event_borrow_payload_field_const (const bt_event *event) |
Borrows the payload field of the event event (const version). | |
bt_field * | bt_event_borrow_specific_context_field (bt_event *event) |
Borrows the specific context field of the event event. | |
const bt_field * | bt_event_borrow_specific_context_field_const (const bt_event *event) |
Borrows the specific context field of the event event (const version). | |
bt_field * | bt_event_borrow_common_context_field (bt_event *event) |
Borrows the common context field of the event event. | |
const bt_field * | bt_event_borrow_common_context_field_const (const bt_event *event) |
Borrows the common context field of the event event (const version). | |
Type | |
typedef struct bt_event | bt_event |
Event. | |
|
extern |
Borrows the class of the event event.
[in] | event | Event of which to borrow the class. |
NULL
.const
version of this function.
|
extern |
Borrows the class of the event event (const
version).
Borrows the stream conceptually containing the event event.
[in] | event | Event of which to borrow the stream conceptually containing it. |
NULL
.const
version of this function. Borrows the stream conceptually containing the event event (const
version).
Borrows the packet conceptually containing the event event.
[in] | event | Event of which to borrow the packet conceptually containing it. |
NULL
.const
version of this function. Borrows the packet conceptually containing the event event (const
version).
Borrows the payload field of the event event.
See the payload field property.
[in] | event | Event of which to borrow the payload field. |
NULL
if none.NULL
.const
version of this function. Borrows the payload field of the event event (const
version).
Borrows the specific context field of the event event.
See the specific context field property.
[in] | event | Event of which to borrow the specific context field. |
NULL
if none.NULL
.const
version of this function. Borrows the specific context field of the event event (const
version).
Borrows the common context field of the event event.
See the common context field property.
[in] | event | Event of which to borrow the common context field. |
NULL
if none.NULL
.const
version of this function. Borrows the common context field of the event event (const
version).