X-Git-Url: http://git.efficios.com/?p=babeltrace.git;a=blobdiff_plain;f=include%2Fbabeltrace%2Fformat.h;h=ef340da115b9432abdad0f35d6e5e94a3d23e52b;hp=bba056cc5a7c799a99451f265ae15248645e1c9b;hb=98ef24741ffe8c7403760763f8b5b9f9154f8054;hpb=06789ffdba97a7be3cceae51e97e82cc5a6c318a diff --git a/include/babeltrace/format.h b/include/babeltrace/format.h index bba056cc..ef340da1 100644 --- a/include/babeltrace/format.h +++ b/include/babeltrace/format.h @@ -22,13 +22,20 @@ */ #include +#include #include #include +#ifdef __cplusplus +extern "C" { +#endif + typedef int bt_intern_str; /* forward declaration */ struct stream_pos; +struct bt_context; +struct bt_trace_handle; /* Parent trace descriptor */ struct trace_descriptor { @@ -48,14 +55,23 @@ struct format { struct trace_descriptor *(*open_trace)(const char *path, int flags, void (*packet_seek)(struct stream_pos *pos, - size_t offset, int whence), + size_t index, int whence), FILE *metadata_fp); struct trace_descriptor *(*open_mmap_trace)( struct mmap_stream_list *mmap_list, void (*packet_seek)(struct stream_pos *pos, - size_t offset, int whence), + size_t index, int whence), FILE *metadata_fp); void (*close_trace)(struct trace_descriptor *descriptor); + void (*set_context)(struct trace_descriptor *descriptor, + struct bt_context *ctx); + void (*set_handle)(struct trace_descriptor *descriptor, + struct bt_trace_handle *handle); + uint64_t (*timestamp_begin)(struct trace_descriptor *descriptor, + struct bt_trace_handle *handle, enum bt_clock_type type); + uint64_t (*timestamp_end)(struct trace_descriptor *descriptor, + struct bt_trace_handle *handle, enum bt_clock_type type); + int (*convert_index_timestamp)(struct trace_descriptor *descriptor); }; extern struct format *bt_lookup_format(bt_intern_str qname); @@ -63,5 +79,8 @@ extern void bt_fprintf_format_list(FILE *fp); extern int bt_register_format(struct format *format); /* TBD: format unregistration */ +#ifdef __cplusplus +} +#endif #endif /* _BABELTRACE_FORMAT_H */