1 #ifndef BABELTRACE_CTF_IR_TRACE_INTERNAL_H
2 #define BABELTRACE_CTF_IR_TRACE_INTERNAL_H
5 * BabelTrace - CTF IR: Trace internal
7 * Copyright 2014 Jérémie Galarneau <jeremie.galarneau@efficios.com>
9 * Author: Jérémie Galarneau <jeremie.galarneau@efficios.com>
11 * Permission is hereby granted, free of charge, to any person obtaining a copy
12 * of this software and associated documentation files (the "Software"), to deal
13 * in the Software without restriction, including without limitation the rights
14 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
15 * copies of the Software, and to permit persons to whom the Software is
16 * furnished to do so, subject to the following conditions:
18 * The above copyright notice and this permission notice shall be included in
19 * all copies or substantial portions of the Software.
21 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
22 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
23 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
24 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
25 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
26 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
30 #include <babeltrace/ctf-ir/trace.h>
31 #include <babeltrace/ctf-ir/field-types.h>
32 #include <babeltrace/ctf-ir/fields.h>
33 #include <babeltrace/object-internal.h>
34 #include <babeltrace/babeltrace-internal.h>
35 #include <babeltrace/values.h>
37 #include <sys/types.h>
38 #include <uuid/uuid.h>
40 enum field_type_alias
{
41 FIELD_TYPE_ALIAS_UINT5_T
= 0,
42 FIELD_TYPE_ALIAS_UINT8_T
,
43 FIELD_TYPE_ALIAS_UINT16_T
,
44 FIELD_TYPE_ALIAS_UINT27_T
,
45 FIELD_TYPE_ALIAS_UINT32_T
,
46 FIELD_TYPE_ALIAS_UINT64_T
,
51 struct bt_object base
;
55 enum bt_ctf_byte_order native_byte_order
;
56 struct bt_value
*environment
;
57 GPtrArray
*clocks
; /* Array of pointers to bt_ctf_clock_class */
58 GPtrArray
*stream_classes
; /* Array of ptrs to bt_ctf_stream_class */
59 GPtrArray
*streams
; /* Array of ptrs to bt_ctf_stream */
60 struct bt_ctf_field_type
*packet_header_type
;
61 uint64_t next_stream_id
;
62 int is_created_by_writer
;
65 * This flag indicates if the trace is valid. A valid
66 * trace is _always_ frozen.
69 GPtrArray
*listeners
; /* Array of struct listener_wrapper */
72 struct metadata_context
{
75 unsigned int current_indentation_level
;
79 const char *get_byte_order_string(int byte_order
);
82 struct bt_ctf_field_type
*get_field_type(enum field_type_alias alias
);
85 int bt_ctf_trace_object_modification(struct bt_ctf_object
*object
,
89 bool bt_ctf_trace_has_clock_class(struct bt_ctf_trace
*trace
,
90 struct bt_ctf_clock_class
*clock_class
);
93 @brief User function type to use with bt_ctf_trace_add_listener().
95 @param[in] obj New CTF IR object which is part of the trace
97 @param[in] data User data.
101 typedef void (*bt_ctf_listener_cb
)(struct bt_ctf_object
*obj
, void *data
);
104 @brief Adds the trace class modification listener \p listener to
105 the CTF IR trace class \p trace_class.
107 Once you add \p listener to \p trace_class, whenever \p trace_class
108 is modified, \p listener is called with the new element and with
111 @param[in] trace_class Trace class to which to add \p listener.
112 @param[in] listener Modification listener function.
113 @param[in] data User data.
114 @returns 0 on success, or a negative value on error.
116 @prenotnull{trace_class}
117 @prenotnull{listener}
118 @postrefcountsame{trace_class}
120 extern int bt_ctf_trace_add_listener(struct bt_ctf_trace
*trace_class
,
121 bt_ctf_listener_cb listener
, void *data
);
123 #endif /* BABELTRACE_CTF_IR_TRACE_INTERNAL_H */