mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-02-23 18:52:09 +01:00
glist: Add debug metrics for gnome-shell
This commit is contained in:
parent
0d0f70792e
commit
1250a4cc85
194
glib/glist.c
194
glib/glist.c
@ -149,7 +149,98 @@
|
|||||||
|
|
||||||
#define _g_list_alloc() g_slice_new (GList)
|
#define _g_list_alloc() g_slice_new (GList)
|
||||||
#define _g_list_alloc0() g_slice_new0 (GList)
|
#define _g_list_alloc0() g_slice_new0 (GList)
|
||||||
#define _g_list_free1(list) g_slice_free (GList, list)
|
#define _g_list_free1(list) ({ if (list && list->prev == NULL) { remove_list_from_metrics_table (list); } ; g_slice_free (GList, list); })
|
||||||
|
|
||||||
|
static GMetricsTable *metrics_table;
|
||||||
|
G_LOCK_DEFINE_STATIC (metrics);
|
||||||
|
|
||||||
|
static void
|
||||||
|
init_metrics (void)
|
||||||
|
{
|
||||||
|
static gsize initialized;
|
||||||
|
|
||||||
|
if (g_once_init_enter (&initialized))
|
||||||
|
{
|
||||||
|
if (g_metrics_requested ("lists"))
|
||||||
|
metrics_table = g_metrics_table_new (sizeof (GListMetrics));
|
||||||
|
g_once_init_leave (&initialized, TRUE);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
add_list_to_metrics_table (GList *list)
|
||||||
|
{
|
||||||
|
GListMetrics metrics = { 0 };
|
||||||
|
char name[sizeof("0xdeadbeefdeadbeef")] = "";
|
||||||
|
|
||||||
|
if (!metrics_table)
|
||||||
|
return;
|
||||||
|
|
||||||
|
G_LOCK (metrics);
|
||||||
|
g_snprintf (name, sizeof name, "%p", list);
|
||||||
|
metrics.length = g_list_length (list);
|
||||||
|
g_metrics_table_set_record (metrics_table, name, &metrics);
|
||||||
|
G_UNLOCK (metrics);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
update_list_in_metrics_table (GList *list,
|
||||||
|
gboolean orphaned)
|
||||||
|
{
|
||||||
|
GListMetrics *metrics;
|
||||||
|
char name[sizeof("0xdeadbeefdeadbeef")] = "";
|
||||||
|
|
||||||
|
if (!metrics_table)
|
||||||
|
return;
|
||||||
|
|
||||||
|
G_LOCK (metrics);
|
||||||
|
g_snprintf (name, sizeof name, "%p", list);
|
||||||
|
metrics = g_metrics_table_get_record (metrics_table, name);
|
||||||
|
if (metrics == NULL)
|
||||||
|
{
|
||||||
|
GListMetrics new_metrics = { 0 };
|
||||||
|
g_metrics_table_set_record (metrics_table, name, &new_metrics);
|
||||||
|
metrics = g_metrics_table_get_record (metrics_table, name);
|
||||||
|
}
|
||||||
|
metrics->length = g_list_length (list);
|
||||||
|
|
||||||
|
if (orphaned)
|
||||||
|
{
|
||||||
|
static gsize sample_interval = 0, sample_index = 0;
|
||||||
|
|
||||||
|
if (sample_interval == 0)
|
||||||
|
{
|
||||||
|
sample_interval = atoi (getenv ("G_METRICS_STACK_TRACE_SAMPLE_INTERVAL")? : "1000");
|
||||||
|
if (sample_interval == 0)
|
||||||
|
sample_interval = 1000;
|
||||||
|
}
|
||||||
|
|
||||||
|
if ((sample_index % sample_interval) == 0)
|
||||||
|
metrics->stack_trace = g_metrics_stack_trace ();
|
||||||
|
sample_index++;
|
||||||
|
}
|
||||||
|
G_UNLOCK (metrics);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
remove_list_from_metrics_table (GList *list)
|
||||||
|
{
|
||||||
|
GListMetrics *metrics;
|
||||||
|
char name[sizeof("0xdeadbeefdeadbeef")] = "";
|
||||||
|
|
||||||
|
if (!metrics_table)
|
||||||
|
return;
|
||||||
|
|
||||||
|
G_LOCK (metrics);
|
||||||
|
g_snprintf (name, sizeof name, "%p", list);
|
||||||
|
metrics = g_metrics_table_get_record (metrics_table, name);
|
||||||
|
if (metrics)
|
||||||
|
{
|
||||||
|
g_metrics_free (metrics->stack_trace);
|
||||||
|
g_metrics_table_remove_record (metrics_table, name);
|
||||||
|
}
|
||||||
|
G_UNLOCK (metrics);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* g_list_alloc:
|
* g_list_alloc:
|
||||||
@ -179,6 +270,9 @@ g_list_alloc (void)
|
|||||||
void
|
void
|
||||||
g_list_free (GList *list)
|
g_list_free (GList *list)
|
||||||
{
|
{
|
||||||
|
|
||||||
|
if (list && list->prev == NULL)
|
||||||
|
remove_list_from_metrics_table (list);
|
||||||
g_slice_free_chain (GList, list, next);
|
g_slice_free_chain (GList, list, next);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -261,22 +355,30 @@ g_list_append (GList *list,
|
|||||||
GList *new_list;
|
GList *new_list;
|
||||||
GList *last;
|
GList *last;
|
||||||
|
|
||||||
|
init_metrics ();
|
||||||
|
|
||||||
new_list = _g_list_alloc ();
|
new_list = _g_list_alloc ();
|
||||||
new_list->data = data;
|
new_list->data = data;
|
||||||
new_list->next = NULL;
|
new_list->next = NULL;
|
||||||
|
|
||||||
if (list)
|
if (list)
|
||||||
{
|
{
|
||||||
|
GList *first;
|
||||||
last = g_list_last (list);
|
last = g_list_last (list);
|
||||||
/* g_assert (last != NULL); */
|
/* g_assert (last != NULL); */
|
||||||
last->next = new_list;
|
last->next = new_list;
|
||||||
new_list->prev = last;
|
new_list->prev = last;
|
||||||
|
|
||||||
|
first = g_list_first (list);
|
||||||
|
update_list_in_metrics_table (first, FALSE);
|
||||||
|
|
||||||
return list;
|
return list;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
new_list->prev = NULL;
|
new_list->prev = NULL;
|
||||||
|
|
||||||
|
add_list_to_metrics_table (new_list);
|
||||||
return new_list;
|
return new_list;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -311,6 +413,8 @@ g_list_prepend (GList *list,
|
|||||||
{
|
{
|
||||||
GList *new_list;
|
GList *new_list;
|
||||||
|
|
||||||
|
init_metrics ();
|
||||||
|
|
||||||
new_list = _g_list_alloc ();
|
new_list = _g_list_alloc ();
|
||||||
new_list->data = data;
|
new_list->data = data;
|
||||||
new_list->next = list;
|
new_list->next = list;
|
||||||
@ -321,10 +425,14 @@ g_list_prepend (GList *list,
|
|||||||
if (list->prev)
|
if (list->prev)
|
||||||
list->prev->next = new_list;
|
list->prev->next = new_list;
|
||||||
list->prev = new_list;
|
list->prev = new_list;
|
||||||
|
|
||||||
|
remove_list_from_metrics_table (list);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
new_list->prev = NULL;
|
new_list->prev = NULL;
|
||||||
|
|
||||||
|
add_list_to_metrics_table (new_list);
|
||||||
|
|
||||||
return new_list;
|
return new_list;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -348,6 +456,8 @@ g_list_insert (GList *list,
|
|||||||
GList *new_list;
|
GList *new_list;
|
||||||
GList *tmp_list;
|
GList *tmp_list;
|
||||||
|
|
||||||
|
init_metrics ();
|
||||||
|
|
||||||
if (position < 0)
|
if (position < 0)
|
||||||
return g_list_append (list, data);
|
return g_list_append (list, data);
|
||||||
else if (position == 0)
|
else if (position == 0)
|
||||||
@ -364,6 +474,8 @@ g_list_insert (GList *list,
|
|||||||
new_list->next = tmp_list;
|
new_list->next = tmp_list;
|
||||||
tmp_list->prev = new_list;
|
tmp_list->prev = new_list;
|
||||||
|
|
||||||
|
update_list_in_metrics_table (list, FALSE);
|
||||||
|
|
||||||
return list;
|
return list;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -383,10 +495,14 @@ g_list_insert_before (GList *list,
|
|||||||
GList *sibling,
|
GList *sibling,
|
||||||
gpointer data)
|
gpointer data)
|
||||||
{
|
{
|
||||||
|
init_metrics ();
|
||||||
|
|
||||||
if (!list)
|
if (!list)
|
||||||
{
|
{
|
||||||
|
|
||||||
list = g_list_alloc ();
|
list = g_list_alloc ();
|
||||||
list->data = data;
|
list->data = data;
|
||||||
|
add_list_to_metrics_table (list);
|
||||||
g_return_val_if_fail (sibling == NULL, list);
|
g_return_val_if_fail (sibling == NULL, list);
|
||||||
return list;
|
return list;
|
||||||
}
|
}
|
||||||
@ -394,6 +510,8 @@ g_list_insert_before (GList *list,
|
|||||||
{
|
{
|
||||||
GList *node;
|
GList *node;
|
||||||
|
|
||||||
|
if (sibling->prev == NULL)
|
||||||
|
remove_list_from_metrics_table (sibling);
|
||||||
node = _g_list_alloc ();
|
node = _g_list_alloc ();
|
||||||
node->data = data;
|
node->data = data;
|
||||||
node->prev = sibling->prev;
|
node->prev = sibling->prev;
|
||||||
@ -401,11 +519,17 @@ g_list_insert_before (GList *list,
|
|||||||
sibling->prev = node;
|
sibling->prev = node;
|
||||||
if (node->prev)
|
if (node->prev)
|
||||||
{
|
{
|
||||||
|
GList *first;
|
||||||
node->prev->next = node;
|
node->prev->next = node;
|
||||||
|
|
||||||
|
first = g_list_first (node);
|
||||||
|
update_list_in_metrics_table (first, FALSE);
|
||||||
|
|
||||||
return list;
|
return list;
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
add_list_to_metrics_table (list);
|
||||||
g_return_val_if_fail (sibling == list, node);
|
g_return_val_if_fail (sibling == list, node);
|
||||||
return node;
|
return node;
|
||||||
}
|
}
|
||||||
@ -413,6 +537,7 @@ g_list_insert_before (GList *list,
|
|||||||
else
|
else
|
||||||
{
|
{
|
||||||
GList *last;
|
GList *last;
|
||||||
|
GList *first;
|
||||||
|
|
||||||
last = list;
|
last = list;
|
||||||
while (last->next)
|
while (last->next)
|
||||||
@ -423,6 +548,9 @@ g_list_insert_before (GList *list,
|
|||||||
last->next->prev = last;
|
last->next->prev = last;
|
||||||
last->next->next = NULL;
|
last->next->next = NULL;
|
||||||
|
|
||||||
|
first = g_list_first (list);
|
||||||
|
update_list_in_metrics_table (first, FALSE);
|
||||||
|
|
||||||
return list;
|
return list;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -454,6 +582,9 @@ g_list_concat (GList *list1,
|
|||||||
|
|
||||||
if (list2)
|
if (list2)
|
||||||
{
|
{
|
||||||
|
if (list2->prev == NULL)
|
||||||
|
remove_list_from_metrics_table (list2);
|
||||||
|
|
||||||
tmp_list = g_list_last (list1);
|
tmp_list = g_list_last (list1);
|
||||||
if (tmp_list)
|
if (tmp_list)
|
||||||
tmp_list->next = list2;
|
tmp_list->next = list2;
|
||||||
@ -462,6 +593,8 @@ g_list_concat (GList *list1,
|
|||||||
list2->prev = tmp_list;
|
list2->prev = tmp_list;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
update_list_in_metrics_table (list1, FALSE);
|
||||||
|
|
||||||
return list1;
|
return list1;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -469,6 +602,8 @@ static inline GList *
|
|||||||
_g_list_remove_link (GList *list,
|
_g_list_remove_link (GList *list,
|
||||||
GList *link)
|
GList *link)
|
||||||
{
|
{
|
||||||
|
GList *first;
|
||||||
|
|
||||||
if (link == NULL)
|
if (link == NULL)
|
||||||
return list;
|
return list;
|
||||||
|
|
||||||
@ -479,6 +614,7 @@ _g_list_remove_link (GList *list,
|
|||||||
else
|
else
|
||||||
g_warning ("corrupted double-linked list detected");
|
g_warning ("corrupted double-linked list detected");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (link->next)
|
if (link->next)
|
||||||
{
|
{
|
||||||
if (link->next->prev == link)
|
if (link->next->prev == link)
|
||||||
@ -488,11 +624,21 @@ _g_list_remove_link (GList *list,
|
|||||||
}
|
}
|
||||||
|
|
||||||
if (link == list)
|
if (link == list)
|
||||||
|
{
|
||||||
|
if (list->prev == NULL)
|
||||||
|
remove_list_from_metrics_table (list);
|
||||||
|
|
||||||
list = list->next;
|
list = list->next;
|
||||||
|
}
|
||||||
|
|
||||||
|
first = g_list_first (list);
|
||||||
|
update_list_in_metrics_table (first, FALSE);
|
||||||
|
|
||||||
link->next = NULL;
|
link->next = NULL;
|
||||||
link->prev = NULL;
|
link->prev = NULL;
|
||||||
|
|
||||||
|
update_list_in_metrics_table (link, TRUE);
|
||||||
|
|
||||||
return list;
|
return list;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -558,10 +704,18 @@ g_list_remove_all (GList *list,
|
|||||||
if (tmp->prev)
|
if (tmp->prev)
|
||||||
tmp->prev->next = next;
|
tmp->prev->next = next;
|
||||||
else
|
else
|
||||||
|
{
|
||||||
|
remove_list_from_metrics_table (list);
|
||||||
list = next;
|
list = next;
|
||||||
|
}
|
||||||
if (next)
|
if (next)
|
||||||
|
{
|
||||||
next->prev = tmp->prev;
|
next->prev = tmp->prev;
|
||||||
|
|
||||||
|
if (next->prev == NULL)
|
||||||
|
add_list_to_metrics_table (list);
|
||||||
|
}
|
||||||
|
|
||||||
_g_list_free1 (tmp);
|
_g_list_free1 (tmp);
|
||||||
tmp = next;
|
tmp = next;
|
||||||
}
|
}
|
||||||
@ -674,6 +828,8 @@ g_list_copy_deep (GList *list,
|
|||||||
{
|
{
|
||||||
GList *new_list = NULL;
|
GList *new_list = NULL;
|
||||||
|
|
||||||
|
init_metrics ();
|
||||||
|
|
||||||
if (list)
|
if (list)
|
||||||
{
|
{
|
||||||
GList *last;
|
GList *last;
|
||||||
@ -699,6 +855,7 @@ g_list_copy_deep (GList *list,
|
|||||||
}
|
}
|
||||||
last->next = NULL;
|
last->next = NULL;
|
||||||
}
|
}
|
||||||
|
add_list_to_metrics_table (new_list);
|
||||||
|
|
||||||
return new_list;
|
return new_list;
|
||||||
}
|
}
|
||||||
@ -717,6 +874,7 @@ g_list_reverse (GList *list)
|
|||||||
{
|
{
|
||||||
GList *last;
|
GList *last;
|
||||||
|
|
||||||
|
remove_list_from_metrics_table (list);
|
||||||
last = NULL;
|
last = NULL;
|
||||||
while (list)
|
while (list)
|
||||||
{
|
{
|
||||||
@ -726,6 +884,8 @@ g_list_reverse (GList *list)
|
|||||||
last->prev = list;
|
last->prev = list;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
add_list_to_metrics_table (last);
|
||||||
|
|
||||||
return last;
|
return last;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1025,10 +1185,13 @@ g_list_insert_sorted_real (GList *list,
|
|||||||
|
|
||||||
g_return_val_if_fail (func != NULL, list);
|
g_return_val_if_fail (func != NULL, list);
|
||||||
|
|
||||||
|
init_metrics ();
|
||||||
|
|
||||||
if (!list)
|
if (!list)
|
||||||
{
|
{
|
||||||
new_list = _g_list_alloc0 ();
|
new_list = _g_list_alloc0 ();
|
||||||
new_list->data = data;
|
new_list->data = data;
|
||||||
|
add_list_to_metrics_table (new_list);
|
||||||
return new_list;
|
return new_list;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1048,6 +1211,7 @@ g_list_insert_sorted_real (GList *list,
|
|||||||
{
|
{
|
||||||
tmp_list->next = new_list;
|
tmp_list->next = new_list;
|
||||||
new_list->prev = tmp_list;
|
new_list->prev = tmp_list;
|
||||||
|
update_list_in_metrics_table (list, FALSE);
|
||||||
return list;
|
return list;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1059,6 +1223,16 @@ g_list_insert_sorted_real (GList *list,
|
|||||||
new_list->next = tmp_list;
|
new_list->next = tmp_list;
|
||||||
tmp_list->prev = new_list;
|
tmp_list->prev = new_list;
|
||||||
|
|
||||||
|
if (new_list->prev == NULL)
|
||||||
|
{
|
||||||
|
remove_list_from_metrics_table (list);
|
||||||
|
add_list_to_metrics_table (new_list);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
update_list_in_metrics_table (list, FALSE);
|
||||||
|
}
|
||||||
|
|
||||||
if (tmp_list == list)
|
if (tmp_list == list)
|
||||||
return new_list;
|
return new_list;
|
||||||
else
|
else
|
||||||
@ -1132,6 +1306,9 @@ g_list_sort_merge (GList *l1,
|
|||||||
GList list, *l, *lprev;
|
GList list, *l, *lprev;
|
||||||
gint cmp;
|
gint cmp;
|
||||||
|
|
||||||
|
remove_list_from_metrics_table (l1);
|
||||||
|
remove_list_from_metrics_table (l2);
|
||||||
|
|
||||||
l = &list;
|
l = &list;
|
||||||
lprev = NULL;
|
lprev = NULL;
|
||||||
|
|
||||||
@ -1156,6 +1333,7 @@ g_list_sort_merge (GList *l1,
|
|||||||
l->next = l1 ? l1 : l2;
|
l->next = l1 ? l1 : l2;
|
||||||
l->next->prev = l;
|
l->next->prev = l;
|
||||||
|
|
||||||
|
add_list_to_metrics_table (list.next);
|
||||||
return list.next;
|
return list.next;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -1255,3 +1433,17 @@ g_list_sort_with_data (GList *list,
|
|||||||
{
|
{
|
||||||
return g_list_sort_real (list, (GFunc) compare_func, user_data);
|
return g_list_sort_real (list, (GFunc) compare_func, user_data);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
GMetricsTable *
|
||||||
|
g_list_lock_metrics_table (void)
|
||||||
|
{
|
||||||
|
G_LOCK (metrics);
|
||||||
|
return metrics_table;
|
||||||
|
}
|
||||||
|
|
||||||
|
void
|
||||||
|
g_list_unlock_metrics_table (void)
|
||||||
|
{
|
||||||
|
G_UNLOCK (metrics);
|
||||||
|
}
|
||||||
|
|
||||||
|
13
glib/glist.h
13
glib/glist.h
@ -31,6 +31,7 @@
|
|||||||
|
|
||||||
#include <glib/gmem.h>
|
#include <glib/gmem.h>
|
||||||
#include <glib/gnode.h>
|
#include <glib/gnode.h>
|
||||||
|
#include <glib/gmetrics.h>
|
||||||
|
|
||||||
G_BEGIN_DECLS
|
G_BEGIN_DECLS
|
||||||
|
|
||||||
@ -147,6 +148,18 @@ gpointer g_list_nth_data (GList *list,
|
|||||||
#define g_list_previous(list) ((list) ? (((GList *)(list))->prev) : NULL)
|
#define g_list_previous(list) ((list) ? (((GList *)(list))->prev) : NULL)
|
||||||
#define g_list_next(list) ((list) ? (((GList *)(list))->next) : NULL)
|
#define g_list_next(list) ((list) ? (((GList *)(list))->next) : NULL)
|
||||||
|
|
||||||
|
|
||||||
|
typedef struct _GListMetrics GListMetrics;
|
||||||
|
struct _GListMetrics
|
||||||
|
{
|
||||||
|
gsize length;
|
||||||
|
char *stack_trace;
|
||||||
|
};
|
||||||
|
|
||||||
|
GLIB_AVAILABLE_IN_ALL
|
||||||
|
GMetricsTable *g_list_lock_metrics_table (void);
|
||||||
|
GLIB_AVAILABLE_IN_ALL
|
||||||
|
void g_list_unlock_metrics_table (void);
|
||||||
G_END_DECLS
|
G_END_DECLS
|
||||||
|
|
||||||
#endif /* __G_LIST_H__ */
|
#endif /* __G_LIST_H__ */
|
||||||
|
28
glib/gmain.c
28
glib/gmain.c
@ -612,6 +612,7 @@ static GMetricsFile *sources_metrics_file;
|
|||||||
static GMetricsFile *memory_metrics_file;
|
static GMetricsFile *memory_metrics_file;
|
||||||
static GMetricsFile *slice_metrics_file;
|
static GMetricsFile *slice_metrics_file;
|
||||||
static GMetricsFile *slice_metrics_traces_file;
|
static GMetricsFile *slice_metrics_traces_file;
|
||||||
|
static GMetricsFile *list_metrics_file;
|
||||||
static long old_total_sources = 0;
|
static long old_total_sources = 0;
|
||||||
|
|
||||||
static gboolean
|
static gboolean
|
||||||
@ -813,6 +814,24 @@ on_metrics_timeout (void)
|
|||||||
g_slice_unlock_metrics ();
|
g_slice_unlock_metrics ();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (list_metrics_file)
|
||||||
|
{
|
||||||
|
GMetricsTable *list_metrics_table;
|
||||||
|
GMetricsTableIter iter;
|
||||||
|
GListMetrics *list_metrics;
|
||||||
|
const char *name;
|
||||||
|
|
||||||
|
list_metrics_table = g_list_lock_metrics_table ();
|
||||||
|
g_metrics_table_iter_init (&iter, list_metrics_table);
|
||||||
|
while (g_metrics_table_iter_next (&iter, &name, &list_metrics))
|
||||||
|
g_metrics_file_add_row (list_metrics_file,
|
||||||
|
name,
|
||||||
|
list_metrics->length,
|
||||||
|
list_metrics->stack_trace? : "");
|
||||||
|
g_list_unlock_metrics_table ();
|
||||||
|
g_metrics_file_end_record (list_metrics_file);
|
||||||
|
}
|
||||||
|
|
||||||
G_LOCK (main_context_list);
|
G_LOCK (main_context_list);
|
||||||
|
|
||||||
if (sources_metrics_file)
|
if (sources_metrics_file)
|
||||||
@ -919,7 +938,7 @@ g_main_context_new (void)
|
|||||||
static gsize initialised;
|
static gsize initialised;
|
||||||
GMainContext *context;
|
GMainContext *context;
|
||||||
GSource *metrics_timeout_source = NULL;
|
GSource *metrics_timeout_source = NULL;
|
||||||
gboolean needs_event_loop_metrics = FALSE, needs_event_loop_totals_metrics = FALSE, needs_mem_metrics = FALSE, needs_slice_metrics = FALSE, needs_slice_traces = FALSE;
|
gboolean needs_event_loop_metrics = FALSE, needs_event_loop_totals_metrics = FALSE, needs_mem_metrics = FALSE, needs_slice_metrics = FALSE, needs_slice_traces = FALSE, needs_list_metrics = FALSE;
|
||||||
|
|
||||||
if (g_once_init_enter (&initialised))
|
if (g_once_init_enter (&initialised))
|
||||||
{
|
{
|
||||||
@ -977,6 +996,7 @@ g_main_context_new (void)
|
|||||||
needs_mem_metrics = g_metrics_requested ("memory-usage");
|
needs_mem_metrics = g_metrics_requested ("memory-usage");
|
||||||
needs_slice_metrics = g_metrics_requested ("slice-memory-usage");
|
needs_slice_metrics = g_metrics_requested ("slice-memory-usage");
|
||||||
needs_slice_traces = g_metrics_requested ("slice-stack-traces");
|
needs_slice_traces = g_metrics_requested ("slice-stack-traces");
|
||||||
|
needs_list_metrics = g_metrics_requested ("lists");
|
||||||
}
|
}
|
||||||
|
|
||||||
if (needs_event_loop_totals_metrics)
|
if (needs_event_loop_totals_metrics)
|
||||||
@ -1019,6 +1039,12 @@ g_main_context_new (void)
|
|||||||
"number of hits", "%ld",
|
"number of hits", "%ld",
|
||||||
"stack trace", "%s",
|
"stack trace", "%s",
|
||||||
NULL);
|
NULL);
|
||||||
|
if (needs_list_metrics)
|
||||||
|
list_metrics_file = g_metrics_file_new ("lists",
|
||||||
|
"address", "%s",
|
||||||
|
"length", "%ld",
|
||||||
|
"stack trace", "%s",
|
||||||
|
NULL);
|
||||||
if (needs_event_loop_metrics || needs_event_loop_totals_metrics || needs_mem_metrics || needs_slice_metrics || needs_list_metrics)
|
if (needs_event_loop_metrics || needs_event_loop_totals_metrics || needs_mem_metrics || needs_slice_metrics || needs_list_metrics)
|
||||||
g_metrics_start_timeout (on_metrics_timeout);
|
g_metrics_start_timeout (on_metrics_timeout);
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user