Added bt_ctf_get_decl_event_id() API function.
authorAmit Margalit <amitm@il.ibm.com>
Tue, 8 Apr 2014 07:51:00 +0000 (10:51 +0300)
committerJérémie Galarneau <jeremie.galarneau@efficios.com>
Tue, 8 Apr 2014 16:20:56 +0000 (12:20 -0400)
Signed-Off-By: Amit Margalit <amitm@il.ibm.com>
Signed-off-by: Jérémie Galarneau <jeremie.galarneau@efficios.com>
bindings/python/babeltrace.i.in
formats/ctf/events.c
include/babeltrace/ctf/events.h

index 294177fa5920f76c47e85b2747f9e7b5afaa781f..5f87a6ddf3a6af543a517c4b0a7a240b1ce0c769 100644 (file)
@@ -509,6 +509,8 @@ struct bt_ctf_event *bt_ctf_iter_read_event(struct bt_ctf_iter *iter);
 %rename("_bt_ctf_field_get_error") bt_ctf_field_get_error(void);
 %rename("_bt_ctf_get_decl_event_name") bt_ctf_get_decl_event_name(const struct
                bt_ctf_event_decl *event);
+%rename("_bt_ctf_get_decl_event_id") bt_ctf_get_decl_event_id(const struct
+               bt_ctf_event_decl *event);
 %rename("_bt_ctf_get_decl_field_name") bt_ctf_get_decl_field_name(
                const struct bt_ctf_field_decl *field);
 %rename("_bt_ctf_get_decl_from_def") bt_ctf_get_decl_from_def(
@@ -551,6 +553,7 @@ double bt_ctf_get_float(const struct bt_definition *field);
 const struct bt_definition *bt_ctf_get_variant(const struct bt_definition *field);
 int bt_ctf_field_get_error(void);
 const char *bt_ctf_get_decl_event_name(const struct bt_ctf_event_decl *event);
+uint64_t bt_ctf_get_decl_event_id(const struct bt_ctf_event_decl *event);
 const char *bt_ctf_get_decl_field_name(const struct bt_ctf_field_decl *field);
 const struct bt_declaration *bt_ctf_get_decl_from_def(const struct bt_definition *field);
 const struct bt_declaration *bt_ctf_get_decl_from_field_decl(const struct bt_ctf_field_decl *field);
@@ -804,6 +807,7 @@ class FieldError(Exception):
 
 class EventDeclaration(object):
        """Event declaration class.  Do not instantiate."""
+       MAX_UINT64 = 0xFFFFFFFFFFFFFFFF
 
        def __init__(self):
                raise NotImplementedError("EventDeclaration cannot be instantiated")
@@ -813,6 +817,14 @@ class EventDeclaration(object):
                """Return the name of the event or None on error"""
                return _bt_ctf_get_decl_event_name(self._ed)
 
+       @property
+       def id(self):
+               """Return the event-ID of the event or -1 on error"""
+               id = _bt_ctf_get_decl_event_id(self._ed)
+               if id == self.MAX_UINT64:
+                       id = -1
+               return id
+
        @property
        def fields(self):
                """
index 8174293b28e85b80b2038ecec808c3490488636f..ea47a40355940d9707129e433a6246832c82ee17 100644 (file)
@@ -712,6 +712,14 @@ const char *bt_ctf_get_decl_event_name(const struct bt_ctf_event_decl *event)
        return g_quark_to_string(event->parent.name);
 }
 
+uint64_t bt_ctf_get_decl_event_id(const struct bt_ctf_event_decl *event)
+{
+       if (!event)
+               return (uint64_t)(-1);
+
+       return event->parent.id;
+}
+
 int bt_ctf_get_decl_fields(struct bt_ctf_event_decl *event_decl,
                enum bt_ctf_scope scope,
                struct bt_ctf_field_decl const * const **list,
index c81d8852f83207881524129b1186d7a946c7f225..9f068015fd6489b60df5a0476090a88884806cea 100644 (file)
@@ -270,6 +270,11 @@ int bt_ctf_get_event_decl_list(int handle_id, struct bt_context *ctx,
  */
 const char *bt_ctf_get_decl_event_name(const struct bt_ctf_event_decl *event);
 
+/*
+ * bt_ctf_get_decl_event_id: return the event-ID of the event or -1ULL on error
+ */
+uint64_t bt_ctf_get_decl_event_id(const struct bt_ctf_event_decl *event);
+
 /*
  * bt_ctf_get_decl_fields: get all field declarations in a scope of an event
  *
This page took 0.028216 seconds and 4 git commands to generate.