/* sysprof-marks-view.c * * Copyright 2019 Christian Hergert * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . * * SPDX-License-Identifier: GPL-3.0-or-later */ #define G_LOG_DOMAIN "sysprof-marks-view" #include "config.h" #include "sysprof-cell-renderer-duration.h" #include "sysprof-marks-model.h" #include "sysprof-marks-view.h" typedef struct { GtkTreeView *tree_view; SysprofCellRendererDuration *duration_cell; } SysprofMarksViewPrivate; G_DEFINE_TYPE_WITH_PRIVATE (SysprofMarksView, sysprof_marks_view, GTK_TYPE_BIN) static void sysprof_marks_view_class_init (SysprofMarksViewClass *klass) { GtkWidgetClass *widget_class = GTK_WIDGET_CLASS (klass); gtk_widget_class_set_template_from_resource (widget_class, "/org/gnome/sysprof/ui/sysprof-marks-view.ui"); gtk_widget_class_bind_template_child_private (widget_class, SysprofMarksView, tree_view); gtk_widget_class_bind_template_child_private (widget_class, SysprofMarksView, duration_cell); g_type_ensure (SYSPROF_TYPE_CELL_RENDERER_DURATION); } static void sysprof_marks_view_init (SysprofMarksView *self) { gtk_widget_init_template (GTK_WIDGET (self)); } GtkWidget * sysprof_marks_view_new (void) { return g_object_new (SYSPROF_TYPE_MARKS_VIEW, NULL); } static void sysprof_marks_view_load_cb (GObject *object, GAsyncResult *result, gpointer user_data) { g_autoptr(SysprofMarksModel) model = NULL; g_autoptr(GError) error = NULL; g_autoptr(GTask) task = user_data; SysprofMarksView *self; SysprofMarksViewPrivate *priv; gint64 zoom_begin, zoom_end; g_assert (G_IS_ASYNC_RESULT (result)); g_assert (G_IS_TASK (task)); self = g_task_get_source_object (task); priv = sysprof_marks_view_get_instance_private (self); if (!(model = sysprof_marks_model_new_finish (result, &error))) { g_task_return_error (task, g_steal_pointer (&error)); return; } sysprof_marks_model_get_range (model, &zoom_begin, &zoom_end); g_object_set (priv->duration_cell, "zoom-begin", zoom_begin, "zoom-end", zoom_end, NULL); gtk_tree_view_set_model (priv->tree_view, GTK_TREE_MODEL (model)); g_task_return_boolean (task, TRUE); } void sysprof_marks_view_load_async (SysprofMarksView *self, SysprofCaptureReader *reader, SysprofSelection *selection, GCancellable *cancellable, GAsyncReadyCallback callback, gpointer user_data) { g_autoptr(GTask) task = NULL; g_return_if_fail (SYSPROF_IS_MARKS_VIEW (self)); g_return_if_fail (reader != NULL); g_return_if_fail (!selection || SYSPROF_IS_SELECTION (selection)); g_return_if_fail (!cancellable || G_IS_CANCELLABLE (cancellable)); task = g_task_new (self, cancellable, callback, user_data); g_task_set_source_tag (task, sysprof_marks_view_load_async); sysprof_marks_model_new_async (reader, selection, cancellable, sysprof_marks_view_load_cb, g_steal_pointer (&task)); } gboolean sysprof_marks_view_load_finish (SysprofMarksView *self, GAsyncResult *result, GError **error) { g_return_val_if_fail (SYSPROF_IS_MARKS_VIEW (self), FALSE); g_return_val_if_fail (G_IS_TASK (result), FALSE); return g_task_propagate_boolean (G_TASK (result), error); }