import collections.abc
from bt2 import value as bt2_value
from bt2 import stream as bt2_stream
-from bt2 import trace_class as bt2_trace_class
from bt2 import stream_class as bt2_stream_class
import bt2
import functools
import uuid as uuidp
+def _bt2_trace_class():
+ from bt2 import trace_class as bt2_trace_class
+
+ return bt2_trace_class
+
+
class _TraceEnvironmentConst(collections.abc.Mapping):
_create_value_from_ptr_and_get_ref = staticmethod(
bt2_value._create_from_const_ptr_and_get_ref
bt2_value._create_from_const_ptr_and_get_ref
)
_stream_pycls = property(lambda _: bt2_stream._StreamConst)
- _trace_class_pycls = property(lambda _: bt2_trace_class._TraceClassConst)
+ _trace_class_pycls = property(lambda _: _bt2_trace_class()._TraceClassConst)
_trace_env_pycls = property(lambda _: _TraceEnvironmentConst)
def __len__(self):
if not callable(listener):
raise TypeError("'listener' parameter is not callable")
+ handle = utils._ListenerHandle(self.addr)
+
fn = native_bt.bt2_trace_add_destruction_listener
listener_from_native = functools.partial(
- _trace_destruction_listener_from_native, listener
+ _trace_destruction_listener_from_native, listener, handle
)
status, listener_id = fn(self._ptr, listener_from_native)
status, 'cannot add destruction listener to trace object'
)
- return utils._ListenerHandle(listener_id, self)
+ handle._set_listener_id(listener_id)
+
+ return handle
+
+ def remove_destruction_listener(self, listener_handle):
+ utils._check_type(listener_handle, utils._ListenerHandle)
+
+ if listener_handle._addr != self.addr:
+ raise ValueError(
+ 'This trace destruction listener does not match the trace object.'
+ )
+
+ if listener_handle._listener_id is None:
+ raise ValueError('This trace destruction listener was already removed.')
+
+ status = native_bt.trace_remove_destruction_listener(
+ self._ptr, listener_handle._listener_id
+ )
+ utils._handle_func_status(status)
+ listener_handle._invalidate()
class _Trace(_TraceConst):
bt2_value._create_from_ptr_and_get_ref
)
_stream_pycls = property(lambda _: bt2_stream._Stream)
- _trace_class_pycls = property(lambda _: bt2_trace_class._TraceClass)
+ _trace_class_pycls = property(lambda _: _bt2_trace_class()._TraceClass)
_trace_env_pycls = property(lambda _: _TraceEnvironment)
def _name(self, name):
return stream
-def _trace_destruction_listener_from_native(user_listener, trace_ptr):
+def _trace_destruction_listener_from_native(user_listener, handle, trace_ptr):
trace = _TraceConst._create_from_ptr_and_get_ref(trace_ptr)
user_listener(trace)
+ handle._invalidate()