[sysprof/wip/chergert/sysprof-3] libsysprof-ui: add various columns



commit f198c62789afd70f438dc59a676dcfe217ef39ab
Author: Christian Hergert <chergert redhat com>
Date:   Sun May 12 21:59:31 2019 -0700

    libsysprof-ui: add various columns

 src/libsysprof-ui/sysprof-marks-model.c    | 189 ++++++++++++++++++++++++++++-
 src/libsysprof-ui/sysprof-marks-model.h    |   6 +-
 src/libsysprof-ui/ui/sysprof-marks-view.ui |  31 ++++-
 3 files changed, 222 insertions(+), 4 deletions(-)
---
diff --git a/src/libsysprof-ui/sysprof-marks-model.c b/src/libsysprof-ui/sysprof-marks-model.c
index b6ce7cc..bed036e 100644
--- a/src/libsysprof-ui/sysprof-marks-model.c
+++ b/src/libsysprof-ui/sysprof-marks-model.c
@@ -39,9 +39,196 @@ typedef struct
   const gchar *name;
 } Item;
 
+static gint
+sysprof_marks_model_get_n_columns (GtkTreeModel *model)
+{
+  return SYSPROF_MARKS_MODEL_COLUMN_LAST;
+}
+
+static GType
+sysprof_marks_model_get_column_type (GtkTreeModel *model,
+                                     gint          column)
+{
+  switch (column)
+    {
+    case SYSPROF_MARKS_MODEL_COLUMN_GROUP:
+      return G_TYPE_STRING;
+
+    case SYSPROF_MARKS_MODEL_COLUMN_NAME:
+      return G_TYPE_STRING;
+
+    case SYSPROF_MARKS_MODEL_COLUMN_BEGIN_TIME:
+      return G_TYPE_INT64;
+
+    case SYSPROF_MARKS_MODEL_COLUMN_END_TIME:
+      return G_TYPE_INT64;
+
+    case SYSPROF_MARKS_MODEL_COLUMN_DURATION:
+      return G_TYPE_DOUBLE;
+
+    default:
+      return 0;
+    }
+}
+
+static GtkTreePath *
+sysprof_marks_model_get_path (GtkTreeModel *model,
+                              GtkTreeIter  *iter)
+{
+  gint off;
+
+  g_assert (SYSPROF_IS_MARKS_MODEL (model));
+  g_assert (iter != NULL);
+
+  off = GPOINTER_TO_INT (iter->user_data);
+
+  return gtk_tree_path_new_from_indices (off, -1);
+}
+
+static gboolean
+sysprof_marks_model_get_iter (GtkTreeModel *model,
+                              GtkTreeIter  *iter,
+                              GtkTreePath  *path)
+{
+  SysprofMarksModel *self = (SysprofMarksModel *)model;
+  gint off;
+
+  g_assert (SYSPROF_IS_MARKS_MODEL (self));
+  g_assert (iter != NULL);
+  g_assert (path != NULL);
+
+  memset (iter, 0, sizeof *iter);
+
+  if (gtk_tree_path_get_depth (path) != 1)
+    return FALSE;
+
+  off = gtk_tree_path_get_indices (path)[0];
+  iter->user_data = GINT_TO_POINTER (off);
+
+  return off >= 0 && off < self->items->len;
+}
+
+static gboolean
+sysprof_marks_model_iter_next (GtkTreeModel *model,
+                               GtkTreeIter  *iter)
+{
+  SysprofMarksModel *self = (SysprofMarksModel *)model;
+  gint off;
+
+  g_assert (SYSPROF_IS_MARKS_MODEL (self));
+  g_assert (iter != NULL);
+
+  off = GPOINTER_TO_INT (iter->user_data);
+  off++;
+  iter->user_data = GINT_TO_POINTER (off);
+
+  return off < self->items->len;
+}
+
+static gboolean
+sysprof_marks_model_iter_nth_child (GtkTreeModel *model,
+                                    GtkTreeIter  *iter,
+                                    GtkTreeIter  *parent,
+                                    gint          n)
+{
+  SysprofMarksModel *self = (SysprofMarksModel *)model;
+
+  g_assert (SYSPROF_IS_MARKS_MODEL (self));
+  g_assert (iter != NULL);
+
+  if (parent != NULL)
+    return FALSE;
+
+  iter->user_data = GINT_TO_POINTER (n);
+
+  return n < self->items->len;
+}
+
+static gint
+sysprof_marks_model_iter_n_children (GtkTreeModel *model,
+                                     GtkTreeIter  *iter)
+{
+  SysprofMarksModel *self = (SysprofMarksModel *)model;
+
+  g_assert (SYSPROF_IS_MARKS_MODEL (self));
+
+  return iter ? 0 : self->items->len;
+}
+
+static gboolean
+sysprof_marks_model_iter_has_child (GtkTreeModel *model,
+                                    GtkTreeIter  *iter)
+{
+  return FALSE;
+}
+
+static GtkTreeModelFlags
+sysprof_marks_model_get_flags (GtkTreeModel *model)
+{
+  return GTK_TREE_MODEL_LIST_ONLY;
+}
+
+static void
+sysprof_marks_model_get_value (GtkTreeModel *model,
+                               GtkTreeIter  *iter,
+                               gint          column,
+                               GValue       *value)
+{
+  SysprofMarksModel *self = (SysprofMarksModel *)model;
+  const Item *item;
+
+  g_assert (SYSPROF_IS_MARKS_MODEL (self));
+  g_assert (iter != NULL);
+  g_assert (column < SYSPROF_MARKS_MODEL_COLUMN_LAST);
+
+  item = &g_array_index (self->items, Item, GPOINTER_TO_INT (iter->user_data));
+
+  switch (column)
+    {
+    case SYSPROF_MARKS_MODEL_COLUMN_GROUP:
+      g_value_init (value, G_TYPE_STRING);
+      g_value_set_string (value, item->group);
+      break;
+
+    case SYSPROF_MARKS_MODEL_COLUMN_NAME:
+      g_value_init (value, G_TYPE_STRING);
+      g_value_set_string (value, item->name);
+      break;
+
+    case SYSPROF_MARKS_MODEL_COLUMN_BEGIN_TIME:
+      g_value_init (value, G_TYPE_INT64);
+      g_value_set_int64 (value, item->begin_time);
+      break;
+
+    case SYSPROF_MARKS_MODEL_COLUMN_END_TIME:
+      g_value_init (value, G_TYPE_INT64);
+      g_value_set_int64 (value, item->end_time);
+      break;
+
+    case SYSPROF_MARKS_MODEL_COLUMN_DURATION:
+      g_value_init (value, G_TYPE_DOUBLE);
+      if (item->end_time)
+        g_value_set_double (value, (item->end_time - item->begin_time) / (double)(G_USEC_PER_SEC * 1000));
+      break;
+
+    default:
+      break;
+    }
+}
+
 static void
 tree_model_iface_init (GtkTreeModelIface *iface)
 {
+  iface->get_n_columns = sysprof_marks_model_get_n_columns;
+  iface->get_column_type = sysprof_marks_model_get_column_type;
+  iface->get_iter = sysprof_marks_model_get_iter;
+  iface->get_path = sysprof_marks_model_get_path;
+  iface->iter_next = sysprof_marks_model_iter_next;
+  iface->iter_n_children = sysprof_marks_model_iter_n_children;
+  iface->iter_nth_child = sysprof_marks_model_iter_nth_child;
+  iface->iter_has_child = sysprof_marks_model_iter_has_child;
+  iface->get_flags = sysprof_marks_model_get_flags;
+  iface->get_value = sysprof_marks_model_get_value;
 }
 
 G_DEFINE_TYPE_WITH_CODE (SysprofMarksModel, sysprof_marks_model, G_TYPE_OBJECT,
@@ -91,7 +278,7 @@ cursor_foreach_cb (const SysprofCaptureFrame *frame,
 
   g_array_append_val (self->items, item);
 
-  return FALSE;
+  return TRUE;
 }
 
 static void
diff --git a/src/libsysprof-ui/sysprof-marks-model.h b/src/libsysprof-ui/sysprof-marks-model.h
index d0a70be..2f60619 100644
--- a/src/libsysprof-ui/sysprof-marks-model.h
+++ b/src/libsysprof-ui/sysprof-marks-model.h
@@ -29,11 +29,15 @@ G_BEGIN_DECLS
 
 typedef enum
 {
-  SYSPROF_MARKS_MODEL_COLUMN_TEXT,
+  SYSPROF_MARKS_MODEL_COLUMN_GROUP,
+  SYSPROF_MARKS_MODEL_COLUMN_NAME,
   SYSPROF_MARKS_MODEL_COLUMN_BEGIN_TIME,
   SYSPROF_MARKS_MODEL_COLUMN_END_TIME,
+  SYSPROF_MARKS_MODEL_COLUMN_DURATION,
 } SysprofMarksModelColumn;
 
+#define SYSPROF_MARKS_MODEL_COLUMN_LAST (SYSPROF_MARKS_MODEL_COLUMN_DURATION+1)
+
 G_DECLARE_FINAL_TYPE (SysprofMarksModel, sysprof_marks_model, SYSPROF, MARKS_MODEL, GObject)
 
 void               sysprof_marks_model_new_async  (SysprofCaptureReader  *reader,
diff --git a/src/libsysprof-ui/ui/sysprof-marks-view.ui b/src/libsysprof-ui/ui/sysprof-marks-view.ui
index b6011f7..6c23fa1 100644
--- a/src/libsysprof-ui/ui/sysprof-marks-view.ui
+++ b/src/libsysprof-ui/ui/sysprof-marks-view.ui
@@ -9,13 +9,32 @@
             <property name="headers-visible">true</property>
             <property name="visible">true</property>
             <child>
-              <object class="GtkTreeViewColumn" id="text_column">
-                <property name="title" translatable="yes">Mark</property>
+              <object class="GtkTreeViewColumn">
+                <property name="title" translatable="yes">Group</property>
+                <property name="resizable">true</property>
                 <property name="expand">false</property>
                 <child>
                   <object class="GtkCellRendererText" id="text_cell">
                     <property name="xalign">0</property>
                   </object>
+                  <attributes>
+                    <attribute name="text">0</attribute>
+                  </attributes>
+                </child>
+              </object>
+            </child>
+            <child>
+              <object class="GtkTreeViewColumn">
+                <property name="title" translatable="yes">Name</property>
+                <property name="resizable">true</property>
+                <property name="expand">false</property>
+                <child>
+                  <object class="GtkCellRendererText">
+                    <property name="xalign">0</property>
+                  </object>
+                  <attributes>
+                    <attribute name="text">1</attribute>
+                  </attributes>
                 </child>
               </object>
             </child>
@@ -23,6 +42,14 @@
               <object class="GtkTreeViewColumn" id="duration_column">
                 <property name="title" translatable="yes">Duration</property>
                 <property name="expand">true</property>
+                <child>
+                  <object class="GtkCellRendererText" id="duration_cell">
+                    <property name="xalign">0</property>
+                  </object>
+                  <attributes>
+                    <attribute name="text">4</attribute>
+                  </attributes>
+                </child>
               </object>
             </child>
           </object>


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]