X-Git-Url: http://git.efficios.com/?a=blobdiff_plain;f=include%2Fbabeltrace%2Fctf-ir%2Fevent-internal.h;h=85fea18cd4817c5ae70127e0fe8cf4ef2ae0b43d;hb=dc3fffef7b84cc4af1a7c99828fd57a106cd2257;hp=c68316c1549194591b72e972b78c84eb794089bd;hpb=272df73edf74c3d8d6cbbf6450258fdbc9fbad36;p=babeltrace.git diff --git a/include/babeltrace/ctf-ir/event-internal.h b/include/babeltrace/ctf-ir/event-internal.h index c68316c1..85fea18c 100644 --- a/include/babeltrace/ctf-ir/event-internal.h +++ b/include/babeltrace/ctf-ir/event-internal.h @@ -31,18 +31,26 @@ #include #include #include -#include #include #include +#include #include +#include #include +struct bt_ctf_stream_pos; + struct bt_ctf_event { struct bt_object base; struct bt_ctf_event_class *event_class; + struct bt_ctf_packet *packet; struct bt_ctf_field *event_header; + struct bt_ctf_field *stream_event_context; struct bt_ctf_field *context_payload; struct bt_ctf_field *fields_payload; + /* Maps clock classes to bt_ctf_clock_value. */ + GHashTable *clock_values; + int frozen; }; BT_HIDDEN @@ -50,18 +58,18 @@ int bt_ctf_event_validate(struct bt_ctf_event *event); BT_HIDDEN int bt_ctf_event_serialize(struct bt_ctf_event *event, - struct ctf_stream_pos *pos); + struct bt_ctf_stream_pos *pos, + enum bt_ctf_byte_order native_byte_order); -/* - * Attempt to populate the "id" and "timestamp" fields of the event header if - * they are present, unset and their types are integers. - * - * Not finding these fields or encountering unexpected types is not an error - * since the user may have defined a different event header layout. In this - * case, it is expected that the fields be manually populated before appending - * an event to a stream. - */ BT_HIDDEN -int bt_ctf_event_populate_event_header(struct bt_ctf_event *event); +void bt_ctf_event_freeze(struct bt_ctf_event *event); + +static inline +struct bt_ctf_event_class *bt_ctf_event_borrow_event_class( + struct bt_ctf_event *event) +{ + assert(event); + return event->event_class; +} #endif /* BABELTRACE_CTF_IR_EVENT_INTERNAL_H */