sink.ctf.fs: write option field classes and fields
[babeltrace.git] / src / bindings / python / bt2 / bt2 / trace_class.py
CommitLineData
fbbe9302
SM
1# The MIT License (MIT)
2#
3# Copyright (c) 2017 Philippe Proulx <pproulx@efficios.com>
4# Copyright (c) 2018 Francis Deslauriers <francis.deslauriers@efficios.com>
5# Copyright (c) 2019 Simon Marchi <simon.marchi@efficios.com>
6#
7# Permission is hereby granted, free of charge, to any person obtaining a copy
8# of this software and associated documentation files (the "Software"), to deal
9# in the Software without restriction, including without limitation the rights
10# to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
11# copies of the Software, and to permit persons to whom the Software is
12# furnished to do so, subject to the following conditions:
13#
14# The above copyright notice and this permission notice shall be included in
15# all copies or substantial portions of the Software.
16#
17# THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
18# IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
19# FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
20# AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
21# LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
22# OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
23# THE SOFTWARE.
24
2c6f8520 25__all__ = ['_TraceClass']
fbbe9302
SM
26
27import bt2
28from bt2 import native_bt, utils, object
3fb99a22
PP
29from bt2 import stream_class as bt2_stream_class
30from bt2 import field_class as bt2_field_class
31from bt2 import trace as bt2_trace
32from bt2 import trace_class as bt2_trace_class
fbbe9302
SM
33import collections.abc
34import functools
35
36
fbbe9302 37def _trace_class_destruction_listener_from_native(user_listener, trace_class_ptr):
3fb99a22 38 trace_class = bt2_trace_class._TraceClass._create_from_ptr_and_get_ref(
cfbd7cf3
FD
39 trace_class_ptr
40 )
fbbe9302
SM
41 user_listener(trace_class)
42
43
2c6f8520 44class _TraceClass(object._SharedObject, collections.abc.Mapping):
fbbe9302
SM
45 _get_ref = staticmethod(native_bt.trace_class_get_ref)
46 _put_ref = staticmethod(native_bt.trace_class_put_ref)
47
8c2367b8
SM
48 # Instantiate a trace of this class.
49
335a2da5 50 def __call__(self, name=None, uuid=None, env=None):
8c2367b8
SM
51 trace_ptr = native_bt.trace_create(self._ptr)
52
53 if trace_ptr is None:
694c792b 54 raise bt2._MemoryError('cannot create trace class object')
8c2367b8 55
3fb99a22 56 trace = bt2_trace._Trace._create_from_ptr(trace_ptr)
8c2367b8
SM
57
58 if name is not None:
59 trace._name = name
60
335a2da5
PP
61 if uuid is not None:
62 trace._uuid = uuid
63
64 if env is not None:
65 for key, value in env.items():
66 trace.env[key] = value
67
8c2367b8
SM
68 return trace
69
fbbe9302
SM
70 # Number of stream classes in this trace class.
71
72 def __len__(self):
73 count = native_bt.trace_class_get_stream_class_count(self._ptr)
74 assert count >= 0
75 return count
76
77 # Get a stream class by stream id.
78
79 def __getitem__(self, key):
80 utils._check_uint64(key)
81
82 sc_ptr = native_bt.trace_class_borrow_stream_class_by_id_const(self._ptr, key)
83 if sc_ptr is None:
84 raise KeyError(key)
85
3fb99a22 86 return bt2_stream_class._StreamClass._create_from_ptr_and_get_ref(sc_ptr)
fbbe9302
SM
87
88 def __iter__(self):
89 for idx in range(len(self)):
cfbd7cf3
FD
90 sc_ptr = native_bt.trace_class_borrow_stream_class_by_index_const(
91 self._ptr, idx
92 )
fbbe9302
SM
93 assert sc_ptr is not None
94
95 id = native_bt.stream_class_get_id(sc_ptr)
96 assert id >= 0
97
98 yield id
99
cfbd7cf3
FD
100 def create_stream_class(
101 self,
102 id=None,
103 name=None,
104 packet_context_field_class=None,
105 event_common_context_field_class=None,
106 default_clock_class=None,
107 assigns_automatic_event_class_id=True,
108 assigns_automatic_stream_id=True,
109 supports_packets=False,
110 packets_have_beginning_default_clock_snapshot=False,
111 packets_have_end_default_clock_snapshot=False,
112 supports_discarded_events=False,
113 discarded_events_have_default_clock_snapshots=False,
114 supports_discarded_packets=False,
115 discarded_packets_have_default_clock_snapshots=False,
116 ):
fbbe9302
SM
117
118 if self.assigns_automatic_stream_class_id:
119 if id is not None:
cfbd7cf3
FD
120 raise ValueError(
121 'id provided, but trace class assigns automatic stream class ids'
122 )
fbbe9302
SM
123
124 sc_ptr = native_bt.stream_class_create(self._ptr)
125 else:
126 if id is None:
cfbd7cf3
FD
127 raise ValueError(
128 'id not provided, but trace class does not assign automatic stream class ids'
129 )
fbbe9302
SM
130
131 utils._check_uint64(id)
132 sc_ptr = native_bt.stream_class_create_with_id(self._ptr, id)
133
3fb99a22 134 sc = bt2_stream_class._StreamClass._create_from_ptr(sc_ptr)
8c2367b8 135
3cdfbaea
SM
136 if name is not None:
137 sc._name = name
138
3cdfbaea
SM
139 if event_common_context_field_class is not None:
140 sc._event_common_context_field_class = event_common_context_field_class
141
142 if default_clock_class is not None:
143 sc._default_clock_class = default_clock_class
144
26fc5aed
PP
145 # call after `sc._default_clock_class` because, if
146 # `packets_have_beginning_default_clock_snapshot` or
147 # `packets_have_end_default_clock_snapshot` is true, then this
148 # stream class needs a default clock class already.
cfbd7cf3
FD
149 sc._set_supports_packets(
150 supports_packets,
151 packets_have_beginning_default_clock_snapshot,
152 packets_have_end_default_clock_snapshot,
153 )
26fc5aed
PP
154
155 # call after sc._set_supports_packets() because, if
156 # `packet_context_field_class` is not `None`, then this stream
157 # class needs to support packets already.
158 if packet_context_field_class is not None:
159 sc._packet_context_field_class = packet_context_field_class
160
3cdfbaea 161 sc._assigns_automatic_event_class_id = assigns_automatic_event_class_id
8c2367b8 162 sc._assigns_automatic_stream_id = assigns_automatic_stream_id
cfbd7cf3
FD
163 sc._set_supports_discarded_events(
164 supports_discarded_events, discarded_events_have_default_clock_snapshots
165 )
166 sc._set_supports_discarded_packets(
167 supports_discarded_packets, discarded_packets_have_default_clock_snapshots
168 )
8c2367b8 169 return sc
fbbe9302
SM
170
171 @property
172 def assigns_automatic_stream_class_id(self):
173 return native_bt.trace_class_assigns_automatic_stream_class_id(self._ptr)
174
175 def _assigns_automatic_stream_class_id(self, auto_id):
176 utils._check_bool(auto_id)
cfbd7cf3
FD
177 return native_bt.trace_class_set_assigns_automatic_stream_class_id(
178 self._ptr, auto_id
179 )
fbbe9302 180
cfbd7cf3
FD
181 _assigns_automatic_stream_class_id = property(
182 fset=_assigns_automatic_stream_class_id
183 )
fbbe9302 184
3cdfbaea
SM
185 # Field class creation methods.
186
aae30e61 187 def _check_field_class_create_status(self, ptr, type_name):
3cdfbaea 188 if ptr is None:
694c792b 189 raise bt2._MemoryError('cannot create {} field class'.format(type_name))
3cdfbaea 190
aae30e61
PP
191 def create_bool_field_class(self):
192 field_class_ptr = native_bt.field_class_bool_create(self._ptr)
193 self._check_field_class_create_status(field_class_ptr, 'boolean')
194
195 return bt2_field_class._BoolFieldClass._create_from_ptr(field_class_ptr)
196
cfbd7cf3
FD
197 def _create_integer_field_class(
198 self, create_func, py_cls, type_name, field_value_range, preferred_display_base
199 ):
af4bbfc7 200 field_class_ptr = create_func(self._ptr)
aae30e61 201 self._check_field_class_create_status(field_class_ptr, type_name)
af4bbfc7
SM
202
203 field_class = py_cls._create_from_ptr(field_class_ptr)
204
d47b87ac
SM
205 if field_value_range is not None:
206 field_class._field_value_range = field_value_range
af4bbfc7 207
d47b87ac
SM
208 if preferred_display_base is not None:
209 field_class._preferred_display_base = preferred_display_base
af4bbfc7
SM
210
211 return field_class
212
cfbd7cf3
FD
213 def create_signed_integer_field_class(
214 self, field_value_range=None, preferred_display_base=None
215 ):
216 return self._create_integer_field_class(
9c08c816 217 native_bt.field_class_integer_signed_create,
3fb99a22 218 bt2_field_class._SignedIntegerFieldClass,
cfbd7cf3
FD
219 'signed integer',
220 field_value_range,
221 preferred_display_base,
222 )
223
224 def create_unsigned_integer_field_class(
225 self, field_value_range=None, preferred_display_base=None
226 ):
227 return self._create_integer_field_class(
9c08c816 228 native_bt.field_class_integer_unsigned_create,
3fb99a22 229 bt2_field_class._UnsignedIntegerFieldClass,
cfbd7cf3
FD
230 'unsigned integer',
231 field_value_range,
232 preferred_display_base,
233 )
234
235 def create_signed_enumeration_field_class(
236 self, field_value_range=None, preferred_display_base=None
237 ):
238 return self._create_integer_field_class(
9c08c816 239 native_bt.field_class_enumeration_signed_create,
3fb99a22 240 bt2_field_class._SignedEnumerationFieldClass,
cfbd7cf3
FD
241 'signed enumeration',
242 field_value_range,
243 preferred_display_base,
244 )
245
246 def create_unsigned_enumeration_field_class(
247 self, field_value_range=None, preferred_display_base=None
248 ):
249 return self._create_integer_field_class(
9c08c816 250 native_bt.field_class_enumeration_unsigned_create,
3fb99a22 251 bt2_field_class._UnsignedEnumerationFieldClass,
cfbd7cf3
FD
252 'unsigned enumeration',
253 field_value_range,
254 preferred_display_base,
255 )
2ae9f48c
SM
256
257 def create_real_field_class(self, is_single_precision=False):
258 field_class_ptr = native_bt.field_class_real_create(self._ptr)
aae30e61 259 self._check_field_class_create_status(field_class_ptr, 'real')
2ae9f48c 260
3fb99a22 261 field_class = bt2_field_class._RealFieldClass._create_from_ptr(field_class_ptr)
2ae9f48c 262
d47b87ac 263 field_class._is_single_precision = is_single_precision
2ae9f48c
SM
264
265 return field_class
266
3cdfbaea
SM
267 def create_structure_field_class(self):
268 field_class_ptr = native_bt.field_class_structure_create(self._ptr)
aae30e61 269 self._check_field_class_create_status(field_class_ptr, 'structure')
3cdfbaea 270
3fb99a22 271 return bt2_field_class._StructureFieldClass._create_from_ptr(field_class_ptr)
3cdfbaea
SM
272
273 def create_string_field_class(self):
274 field_class_ptr = native_bt.field_class_string_create(self._ptr)
aae30e61 275 self._check_field_class_create_status(field_class_ptr, 'string')
3cdfbaea 276
3fb99a22 277 return bt2_field_class._StringFieldClass._create_from_ptr(field_class_ptr)
d47b87ac
SM
278
279 def create_static_array_field_class(self, elem_fc, length):
3fb99a22 280 utils._check_type(elem_fc, bt2_field_class._FieldClass)
d47b87ac 281 utils._check_uint64(length)
9c08c816 282 ptr = native_bt.field_class_array_static_create(self._ptr, elem_fc._ptr, length)
aae30e61 283 self._check_field_class_create_status(ptr, 'static array')
d47b87ac 284
3fb99a22 285 return bt2_field_class._StaticArrayFieldClass._create_from_ptr_and_get_ref(ptr)
d47b87ac
SM
286
287 def create_dynamic_array_field_class(self, elem_fc, length_fc=None):
3fb99a22 288 utils._check_type(elem_fc, bt2_field_class._FieldClass)
1367bc7c 289 length_fc_ptr = None
d47b87ac
SM
290
291 if length_fc is not None:
3fb99a22 292 utils._check_type(length_fc, bt2_field_class._UnsignedIntegerFieldClass)
1367bc7c 293 length_fc_ptr = length_fc._ptr
d47b87ac 294
9c08c816 295 ptr = native_bt.field_class_array_dynamic_create(
cfbd7cf3
FD
296 self._ptr, elem_fc._ptr, length_fc_ptr
297 )
aae30e61 298 self._check_field_class_create_status(ptr, 'dynamic array')
3fb99a22 299 return bt2_field_class._DynamicArrayFieldClass._create_from_ptr(ptr)
d47b87ac
SM
300
301 def create_variant_field_class(self, selector_fc=None):
45c51519 302 selector_fc_ptr = None
d47b87ac
SM
303
304 if selector_fc is not None:
3fb99a22 305 utils._check_type(selector_fc, bt2_field_class._IntegerFieldClass)
45c51519 306 selector_fc_ptr = selector_fc._ptr
d47b87ac 307
45c51519 308 ptr = native_bt.field_class_variant_create(self._ptr, selector_fc_ptr)
aae30e61 309 self._check_field_class_create_status(ptr, 'variant')
3fb99a22 310 return bt2_field_class._create_field_class_from_ptr_and_get_ref(ptr)
3cdfbaea 311
fbbe9302
SM
312 # Add a listener to be called when the trace class is destroyed.
313
314 def add_destruction_listener(self, listener):
315
316 if not callable(listener):
317 raise TypeError("'listener' parameter is not callable")
318
d24d5663 319 fn = native_bt.bt2_trace_class_add_destruction_listener
cfbd7cf3
FD
320 listener_from_native = functools.partial(
321 _trace_class_destruction_listener_from_native, listener
322 )
fbbe9302 323
ee2cad25
SM
324 status, listener_id = fn(self._ptr, listener_from_native)
325 utils._handle_func_status(
326 status, 'cannot add destruction listener to trace class object'
327 )
fbbe9302 328
3fb99a22 329 return utils._ListenerHandle(listener_id, self)
This page took 0.047447 seconds and 4 git commands to generate.