X-Git-Url: http://git.efficios.com/?p=babeltrace.git;a=blobdiff_plain;f=include%2Fbabeltrace%2Fformat.h;h=c9b84a6f59abf1c4462778a955b37a8b41c5bb2e;hp=b67dd5dc77298d434557f3fe3afe00a1bbd8e8cd;hb=61cf588beae752e5ddfc60b6b5310f769ac9e852;hpb=98a0490342a1b8f8841ef52aaaef2cef11782ff1 diff --git a/include/babeltrace/format.h b/include/babeltrace/format.h index b67dd5dc..c9b84a6f 100644 --- a/include/babeltrace/format.h +++ b/include/babeltrace/format.h @@ -19,55 +19,76 @@ * * The above copyright notice and this permission notice shall be included in * all copies or substantial portions of the Software. + * + * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR + * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, + * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE + * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER + * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, + * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE + * SOFTWARE. */ #include +#include #include #include +#ifdef __cplusplus +extern "C" { +#endif + typedef int bt_intern_str; /* forward declaration */ -struct stream_pos; +struct bt_stream_pos; struct bt_context; struct bt_trace_handle; +struct bt_trace_descriptor; -/* Parent trace descriptor */ -struct trace_descriptor { -}; - -struct mmap_stream { +struct bt_mmap_stream { int fd; struct bt_list_head list; + void *priv; }; -struct mmap_stream_list { +struct bt_mmap_stream_list { struct bt_list_head head; }; -struct format { +struct bt_format { bt_intern_str name; - struct trace_descriptor *(*open_trace)(const char *path, int flags, - void (*packet_seek)(struct stream_pos *pos, + struct bt_trace_descriptor *(*open_trace)(const char *path, int flags, + void (*packet_seek)(struct bt_stream_pos *pos, 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, + struct bt_trace_descriptor *(*open_mmap_trace)( + struct bt_mmap_stream_list *mmap_list, + void (*packet_seek)(struct bt_stream_pos *pos, size_t index, int whence), FILE *metadata_fp); - void (*close_trace)(struct trace_descriptor *descriptor); - void (*set_context)(struct trace_descriptor *descriptor, + int (*close_trace)(struct bt_trace_descriptor *descriptor); + void (*set_context)(struct bt_trace_descriptor *descriptor, struct bt_context *ctx); - void (*set_handle)(struct trace_descriptor *descriptor, + void (*set_handle)(struct bt_trace_descriptor *descriptor, struct bt_trace_handle *handle); + int (*timestamp_begin)(struct bt_trace_descriptor *descriptor, + struct bt_trace_handle *handle, enum bt_clock_type type, + int64_t *timestamp); + int (*timestamp_end)(struct bt_trace_descriptor *descriptor, + struct bt_trace_handle *handle, enum bt_clock_type type, + int64_t *timestamp); + int (*convert_index_timestamp)(struct bt_trace_descriptor *descriptor); }; -extern struct format *bt_lookup_format(bt_intern_str qname); +extern struct bt_format *bt_lookup_format(bt_intern_str qname); extern void bt_fprintf_format_list(FILE *fp); -extern int bt_register_format(struct format *format); +extern int bt_register_format(struct bt_format *format); +extern void bt_unregister_format(struct bt_format *format); -/* TBD: format unregistration */ +#ifdef __cplusplus +} +#endif #endif /* _BABELTRACE_FORMAT_H */