X-Git-Url: http://git.efficios.com/?a=blobdiff_plain;f=include%2Fbabeltrace%2Fctf-ir%2Fevent-internal.h;h=85fea18cd4817c5ae70127e0fe8cf4ef2ae0b43d;hb=dc3fffef7b84cc4af1a7c99828fd57a106cd2257;hp=857ea01d03cbda886e8a1f313a63a0caf17d0aaa;hpb=e6a8e8e4744633807083a077ff9f101eb97d9801;p=babeltrace.git diff --git a/include/babeltrace/ctf-ir/event-internal.h b/include/babeltrace/ctf-ir/event-internal.h index 857ea01d..85fea18c 100644 --- a/include/babeltrace/ctf-ir/event-internal.h +++ b/include/babeltrace/ctf-ir/event-internal.h @@ -2,7 +2,7 @@ #define BABELTRACE_CTF_IR_EVENT_INTERNAL_H /* - * BabelTrace - CTF IR: Event internal + * Babeltrace - CTF IR: Event internal * * Copyright 2013, 2014 Jérémie Galarneau * @@ -31,66 +31,45 @@ #include #include #include -#include #include #include +#include #include +#include #include -#define BT_CTF_EVENT_CLASS_ATTR_ID_INDEX 0 -#define BT_CTF_EVENT_CLASS_ATTR_NAME_INDEX 1 - -struct bt_ctf_event_class { - struct bt_object base; - struct bt_value *attributes; - /* Structure type containing the event's context */ - struct bt_ctf_field_type *context; - /* Structure type containing the event's fields */ - struct bt_ctf_field_type *fields; - int frozen; -}; +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 -void bt_ctf_event_class_freeze(struct bt_ctf_event_class *event_class); - -BT_HIDDEN -int bt_ctf_event_class_serialize(struct bt_ctf_event_class *event_class, - struct metadata_context *context); - -BT_HIDDEN -void bt_ctf_event_class_set_native_byte_order( - struct bt_ctf_event_class *event_class, - int byte_order); - -BT_HIDDEN -int bt_ctf_event_class_set_stream_id(struct bt_ctf_event_class *event_class, - uint32_t stream_id); - BT_HIDDEN 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 */