forked from AuroraMiddleware/gtk
inspector: Add a GraphData object for recording data
This way we can keep more data than just the 2 last values.
This commit is contained in:
parent
14e0283413
commit
0a6755b57c
@ -29,6 +29,8 @@ libgtkinspector_la_SOURCES = \
|
|||||||
general.c \
|
general.c \
|
||||||
gestures.h \
|
gestures.h \
|
||||||
gestures.c \
|
gestures.c \
|
||||||
|
graphdata.h \
|
||||||
|
graphdata.c \
|
||||||
init.h \
|
init.h \
|
||||||
init.c \
|
init.c \
|
||||||
inspect-button.c \
|
inspect-button.c \
|
||||||
|
@ -30,6 +30,7 @@
|
|||||||
#include "data-list.h"
|
#include "data-list.h"
|
||||||
#include "general.h"
|
#include "general.h"
|
||||||
#include "gestures.h"
|
#include "gestures.h"
|
||||||
|
#include "graphdata.h"
|
||||||
#include "menu.h"
|
#include "menu.h"
|
||||||
#include "misc-info.h"
|
#include "misc-info.h"
|
||||||
#include "object-hierarchy.h"
|
#include "object-hierarchy.h"
|
||||||
@ -50,6 +51,7 @@ gtk_inspector_init (void)
|
|||||||
{
|
{
|
||||||
gtk_inspector_register_resource ();
|
gtk_inspector_register_resource ();
|
||||||
|
|
||||||
|
g_type_ensure (GTK_TYPE_GRAPH_DATA);
|
||||||
g_type_ensure (GTK_TYPE_INSPECTOR_ACTIONS);
|
g_type_ensure (GTK_TYPE_INSPECTOR_ACTIONS);
|
||||||
g_type_ensure (GTK_TYPE_INSPECTOR_CLASSES_LIST);
|
g_type_ensure (GTK_TYPE_INSPECTOR_CLASSES_LIST);
|
||||||
g_type_ensure (GTK_TYPE_INSPECTOR_CSS_EDITOR);
|
g_type_ensure (GTK_TYPE_INSPECTOR_CSS_EDITOR);
|
||||||
|
@ -20,6 +20,7 @@
|
|||||||
|
|
||||||
#include "statistics.h"
|
#include "statistics.h"
|
||||||
|
|
||||||
|
#include "graphdata.h"
|
||||||
#include "gtkstack.h"
|
#include "gtkstack.h"
|
||||||
#include "gtktreeview.h"
|
#include "gtktreeview.h"
|
||||||
#include "gtkcellrenderertext.h"
|
#include "gtkcellrenderertext.h"
|
||||||
@ -46,10 +47,8 @@ struct _GtkInspectorStatisticsPrivate
|
|||||||
typedef struct {
|
typedef struct {
|
||||||
GType type;
|
GType type;
|
||||||
GtkTreeIter treeiter;
|
GtkTreeIter treeiter;
|
||||||
gint self1;
|
GtkGraphData *self;
|
||||||
gint cumulative1;
|
GtkGraphData *cumulative;
|
||||||
gint self2;
|
|
||||||
gint cumulative2;
|
|
||||||
} TypeData;
|
} TypeData;
|
||||||
|
|
||||||
enum
|
enum
|
||||||
@ -59,7 +58,9 @@ enum
|
|||||||
COLUMN_SELF1,
|
COLUMN_SELF1,
|
||||||
COLUMN_CUMULATIVE1,
|
COLUMN_CUMULATIVE1,
|
||||||
COLUMN_SELF2,
|
COLUMN_SELF2,
|
||||||
COLUMN_CUMULATIVE2
|
COLUMN_CUMULATIVE2,
|
||||||
|
COLUMN_SELF_DATA,
|
||||||
|
COLUMN_CUMULATIVE_DATA
|
||||||
};
|
};
|
||||||
|
|
||||||
G_DEFINE_TYPE_WITH_PRIVATE (GtkInspectorStatistics, gtk_inspector_statistics, GTK_TYPE_BOX)
|
G_DEFINE_TYPE_WITH_PRIVATE (GtkInspectorStatistics, gtk_inspector_statistics, GTK_TYPE_BOX)
|
||||||
@ -85,10 +86,14 @@ add_type_count (GtkInspectorStatistics *sl, GType type)
|
|||||||
{
|
{
|
||||||
data = g_new0 (TypeData, 1);
|
data = g_new0 (TypeData, 1);
|
||||||
data->type = type;
|
data->type = type;
|
||||||
|
data->self = gtk_graph_data_new (60);
|
||||||
|
data->cumulative = gtk_graph_data_new (60);
|
||||||
gtk_list_store_append (GTK_LIST_STORE (sl->priv->model), &data->treeiter);
|
gtk_list_store_append (GTK_LIST_STORE (sl->priv->model), &data->treeiter);
|
||||||
gtk_list_store_set (GTK_LIST_STORE (sl->priv->model), &data->treeiter,
|
gtk_list_store_set (GTK_LIST_STORE (sl->priv->model), &data->treeiter,
|
||||||
COLUMN_TYPE, data->type,
|
COLUMN_TYPE, data->type,
|
||||||
COLUMN_TYPE_NAME, g_type_name (data->type),
|
COLUMN_TYPE_NAME, g_type_name (data->type),
|
||||||
|
COLUMN_SELF_DATA, data->self,
|
||||||
|
COLUMN_CUMULATIVE_DATA, data->cumulative,
|
||||||
-1);
|
-1);
|
||||||
g_hash_table_insert (sl->priv->counts, GSIZE_TO_POINTER (type), data);
|
g_hash_table_insert (sl->priv->counts, GSIZE_TO_POINTER (type), data);
|
||||||
}
|
}
|
||||||
@ -96,16 +101,14 @@ add_type_count (GtkInspectorStatistics *sl, GType type)
|
|||||||
self = g_type_get_instance_count (type);
|
self = g_type_get_instance_count (type);
|
||||||
cumulative += self;
|
cumulative += self;
|
||||||
|
|
||||||
data->self1 = data->self2;
|
gtk_graph_data_prepend_value (data->self, self);
|
||||||
data->cumulative1 = data->cumulative2;
|
gtk_graph_data_prepend_value (data->cumulative, cumulative);
|
||||||
data->self2 = self;
|
|
||||||
data->cumulative2 = cumulative;
|
|
||||||
|
|
||||||
gtk_list_store_set (GTK_LIST_STORE (sl->priv->model), &data->treeiter,
|
gtk_list_store_set (GTK_LIST_STORE (sl->priv->model), &data->treeiter,
|
||||||
COLUMN_SELF1, data->self1,
|
COLUMN_SELF1, (int) gtk_graph_data_get_value (data->self, 1),
|
||||||
COLUMN_CUMULATIVE1, data->cumulative1,
|
COLUMN_CUMULATIVE1, (int) gtk_graph_data_get_value (data->cumulative, 1),
|
||||||
COLUMN_SELF2, data->self2,
|
COLUMN_SELF2, (int) gtk_graph_data_get_value (data->self, 0),
|
||||||
COLUMN_CUMULATIVE2, data->cumulative2,
|
COLUMN_CUMULATIVE2, (int) gtk_graph_data_get_value (data->cumulative, 0),
|
||||||
-1);
|
-1);
|
||||||
return cumulative;
|
return cumulative;
|
||||||
}
|
}
|
||||||
@ -202,6 +205,17 @@ cell_data_delta (GtkCellLayout *layout,
|
|||||||
g_free (text);
|
g_free (text);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
type_data_free (gpointer data)
|
||||||
|
{
|
||||||
|
TypeData *type_data = data;
|
||||||
|
|
||||||
|
g_object_unref (type_data->self);
|
||||||
|
g_object_unref (type_data->cumulative);
|
||||||
|
|
||||||
|
g_free (type_data);
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gtk_inspector_statistics_init (GtkInspectorStatistics *sl)
|
gtk_inspector_statistics_init (GtkInspectorStatistics *sl)
|
||||||
{
|
{
|
||||||
@ -223,7 +237,7 @@ gtk_inspector_statistics_init (GtkInspectorStatistics *sl)
|
|||||||
sl->priv->renderer_cumulative2,
|
sl->priv->renderer_cumulative2,
|
||||||
cell_data_delta,
|
cell_data_delta,
|
||||||
GINT_TO_POINTER (COLUMN_CUMULATIVE2), NULL);
|
GINT_TO_POINTER (COLUMN_CUMULATIVE2), NULL);
|
||||||
sl->priv->counts = g_hash_table_new_full (NULL, NULL, NULL, g_free);
|
sl->priv->counts = g_hash_table_new_full (NULL, NULL, NULL, type_data_free);
|
||||||
|
|
||||||
if (has_instance_counts ())
|
if (has_instance_counts ())
|
||||||
update_type_counts (sl);
|
update_type_counts (sl);
|
||||||
|
@ -8,6 +8,8 @@
|
|||||||
<column type="gint"/>
|
<column type="gint"/>
|
||||||
<column type="gint"/>
|
<column type="gint"/>
|
||||||
<column type="gint"/>
|
<column type="gint"/>
|
||||||
|
<column type="GtkGraphData"/>
|
||||||
|
<column type="GtkGraphData"/>
|
||||||
</columns>
|
</columns>
|
||||||
</object>
|
</object>
|
||||||
<template class="GtkInspectorStatistics" parent="GtkBox">
|
<template class="GtkInspectorStatistics" parent="GtkBox">
|
||||||
|
Loading…
Reference in New Issue
Block a user