mirror of
https://github.com/varun-r-mallya/sysprof.git
synced 2025-12-31 20:36:25 +00:00
libsysprof-analyze: expose logs as document property
# Conflicts: # src/libsysprof-analyze/sysprof-document.c
This commit is contained in:
@ -76,6 +76,7 @@ struct _SysprofDocument
|
|||||||
EggBitset *samples_with_context_switch;
|
EggBitset *samples_with_context_switch;
|
||||||
EggBitset *traceables;
|
EggBitset *traceables;
|
||||||
EggBitset *processes;
|
EggBitset *processes;
|
||||||
|
EggBitset *logs;
|
||||||
EggBitset *mmaps;
|
EggBitset *mmaps;
|
||||||
EggBitset *overlays;
|
EggBitset *overlays;
|
||||||
EggBitset *pids;
|
EggBitset *pids;
|
||||||
@ -108,6 +109,7 @@ enum {
|
|||||||
PROP_ALLOCATIONS,
|
PROP_ALLOCATIONS,
|
||||||
PROP_COUNTERS,
|
PROP_COUNTERS,
|
||||||
PROP_FILES,
|
PROP_FILES,
|
||||||
|
PROP_LOGS,
|
||||||
PROP_PROCESSES,
|
PROP_PROCESSES,
|
||||||
PROP_SAMPLES,
|
PROP_SAMPLES,
|
||||||
PROP_TIME_SPAN,
|
PROP_TIME_SPAN,
|
||||||
@ -276,6 +278,7 @@ sysprof_document_finalize (GObject *object)
|
|||||||
g_clear_pointer (&self->marks, egg_bitset_unref);
|
g_clear_pointer (&self->marks, egg_bitset_unref);
|
||||||
g_clear_pointer (&self->file_chunks, egg_bitset_unref);
|
g_clear_pointer (&self->file_chunks, egg_bitset_unref);
|
||||||
g_clear_pointer (&self->jitmaps, egg_bitset_unref);
|
g_clear_pointer (&self->jitmaps, egg_bitset_unref);
|
||||||
|
g_clear_pointer (&self->logs, egg_bitset_unref);
|
||||||
g_clear_pointer (&self->mmaps, egg_bitset_unref);
|
g_clear_pointer (&self->mmaps, egg_bitset_unref);
|
||||||
g_clear_pointer (&self->overlays, egg_bitset_unref);
|
g_clear_pointer (&self->overlays, egg_bitset_unref);
|
||||||
g_clear_pointer (&self->pids, egg_bitset_unref);
|
g_clear_pointer (&self->pids, egg_bitset_unref);
|
||||||
@ -319,6 +322,10 @@ sysprof_document_get_property (GObject *object,
|
|||||||
g_value_take_object (value, sysprof_document_list_files (self));
|
g_value_take_object (value, sysprof_document_list_files (self));
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case PROP_LOGS:
|
||||||
|
g_value_take_object (value, sysprof_document_list_logs (self));
|
||||||
|
break;
|
||||||
|
|
||||||
case PROP_PROCESSES:
|
case PROP_PROCESSES:
|
||||||
g_value_take_object (value, sysprof_document_list_processes (self));
|
g_value_take_object (value, sysprof_document_list_processes (self));
|
||||||
break;
|
break;
|
||||||
@ -363,6 +370,11 @@ sysprof_document_class_init (SysprofDocumentClass *klass)
|
|||||||
G_TYPE_LIST_MODEL,
|
G_TYPE_LIST_MODEL,
|
||||||
(G_PARAM_READABLE | G_PARAM_STATIC_STRINGS));
|
(G_PARAM_READABLE | G_PARAM_STATIC_STRINGS));
|
||||||
|
|
||||||
|
properties [PROP_LOGS] =
|
||||||
|
g_param_spec_object ("logs", NULL, NULL,
|
||||||
|
G_TYPE_LIST_MODEL,
|
||||||
|
(G_PARAM_READABLE | G_PARAM_STATIC_STRINGS));
|
||||||
|
|
||||||
properties [PROP_PROCESSES] =
|
properties [PROP_PROCESSES] =
|
||||||
g_param_spec_object ("processes", NULL, NULL,
|
g_param_spec_object ("processes", NULL, NULL,
|
||||||
G_TYPE_LIST_MODEL,
|
G_TYPE_LIST_MODEL,
|
||||||
@ -403,6 +415,7 @@ sysprof_document_init (SysprofDocument *self)
|
|||||||
self->marks = egg_bitset_new_empty ();
|
self->marks = egg_bitset_new_empty ();
|
||||||
self->file_chunks = egg_bitset_new_empty ();
|
self->file_chunks = egg_bitset_new_empty ();
|
||||||
self->jitmaps = egg_bitset_new_empty ();
|
self->jitmaps = egg_bitset_new_empty ();
|
||||||
|
self->logs = egg_bitset_new_empty ();
|
||||||
self->mmaps = egg_bitset_new_empty ();
|
self->mmaps = egg_bitset_new_empty ();
|
||||||
self->overlays = egg_bitset_new_empty ();
|
self->overlays = egg_bitset_new_empty ();
|
||||||
self->pids = egg_bitset_new_empty ();
|
self->pids = egg_bitset_new_empty ();
|
||||||
@ -1059,6 +1072,10 @@ sysprof_document_load_worker (GTask *task,
|
|||||||
egg_bitset_add (self->jitmaps, f);
|
egg_bitset_add (self->jitmaps, f);
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case SYSPROF_CAPTURE_FRAME_LOG:
|
||||||
|
egg_bitset_add (self->logs, f);
|
||||||
|
break;
|
||||||
|
|
||||||
case SYSPROF_CAPTURE_FRAME_MAP:
|
case SYSPROF_CAPTURE_FRAME_MAP:
|
||||||
egg_bitset_add (self->mmaps, f);
|
egg_bitset_add (self->mmaps, f);
|
||||||
break;
|
break;
|
||||||
@ -1720,6 +1737,20 @@ finish:
|
|||||||
return n_symbolized;
|
return n_symbolized;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* sysprof_document_list_logs:
|
||||||
|
* @self: a #SysprofDocument
|
||||||
|
*
|
||||||
|
* Returns: (transfer full): a #GListModel of #SysprofDocumentLog
|
||||||
|
*/
|
||||||
|
GListModel *
|
||||||
|
sysprof_document_list_logs (SysprofDocument *self)
|
||||||
|
{
|
||||||
|
g_return_val_if_fail (SYSPROF_IS_DOCUMENT (self), NULL);
|
||||||
|
|
||||||
|
return _sysprof_document_bitset_index_new (G_LIST_MODEL (self), self->logs);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* sysprof_document_list_counters:
|
* sysprof_document_list_counters:
|
||||||
* @self: a #SysprofDocument
|
* @self: a #SysprofDocument
|
||||||
|
|||||||
@ -53,6 +53,8 @@ GListModel *sysprof_document_list_traceables (SysprofDocume
|
|||||||
SYSPROF_AVAILABLE_IN_ALL
|
SYSPROF_AVAILABLE_IN_ALL
|
||||||
GListModel *sysprof_document_list_allocations (SysprofDocument *self);
|
GListModel *sysprof_document_list_allocations (SysprofDocument *self);
|
||||||
SYSPROF_AVAILABLE_IN_ALL
|
SYSPROF_AVAILABLE_IN_ALL
|
||||||
|
GListModel *sysprof_document_list_logs (SysprofDocument *self);
|
||||||
|
SYSPROF_AVAILABLE_IN_ALL
|
||||||
GListModel *sysprof_document_list_samples (SysprofDocument *self);
|
GListModel *sysprof_document_list_samples (SysprofDocument *self);
|
||||||
SYSPROF_AVAILABLE_IN_ALL
|
SYSPROF_AVAILABLE_IN_ALL
|
||||||
GListModel *sysprof_document_list_samples_with_context_switch
|
GListModel *sysprof_document_list_samples_with_context_switch
|
||||||
|
|||||||
Reference in New Issue
Block a user