[gnome-logs/wip/detail: 4/5] Split off GlEventViewDetail as the detail widget
- From: David King <davidk src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gnome-logs/wip/detail: 4/5] Split off GlEventViewDetail as the detail widget
- Date: Tue, 26 Nov 2013 19:38:32 +0000 (UTC)
commit eab9ba8e3735a6b1ad473805772b6caea1a9be6e
Author: David King <davidk gnome org>
Date: Thu Nov 21 12:01:20 2013 +0000
Split off GlEventViewDetail as the detail widget
Makefile.am | 2 +
src/gl-eventview.c | 56 ++-----------
src/gl-eventviewdetail.c | 207 ++++++++++++++++++++++++++++++++++++++++++++++
src/gl-eventviewdetail.h | 49 +++++++++++
4 files changed, 265 insertions(+), 49 deletions(-)
---
diff --git a/Makefile.am b/Makefile.am
index 011a7a3..6578ddb 100644
--- a/Makefile.am
+++ b/Makefile.am
@@ -24,6 +24,7 @@ gnome_logs_SOURCES = \
src/gl-categorylist.c \
src/gl-eventtoolbar.c \
src/gl-eventview.c \
+ src/gl-eventviewdetail.c \
src/gl-eventviewrow.c \
src/gl-journal.c \
src/gl-main.c \
@@ -49,6 +50,7 @@ noinst_gnome_logs_headers = \
src/gl-categorylist.h \
src/gl-eventtoolbar.h \
src/gl-eventview.h \
+ src/gl-eventviewdetail.h \
src/gl-eventviewrow.h \
src/gl-journal.h \
src/gl-util.h \
diff --git a/src/gl-eventview.c b/src/gl-eventview.c
index 8947d1a..5b4fee4 100644
--- a/src/gl-eventview.c
+++ b/src/gl-eventview.c
@@ -25,6 +25,7 @@
#include "gl-enums.h"
#include "gl-eventtoolbar.h"
+#include "gl-eventviewdetail.h"
#include "gl-eventviewrow.h"
#include "gl-journal.h"
#include "gl-util.h"
@@ -166,62 +167,19 @@ on_listbox_row_activated (GtkListBox *listbox,
{
GlEventViewPrivate *priv;
GlJournalResult *result;
- gchar *time;
- gboolean rtl;
- GtkWidget *grid;
- GtkWidget *label;
- GtkStyleContext *context;
+ GtkWidget *detail;
GtkStack *stack;
priv = gl_event_view_get_instance_private (view);
-
result = gl_event_view_row_get_result (GL_EVENT_VIEW_ROW (row));
- rtl = gtk_widget_get_default_direction () == GTK_TEXT_DIR_RTL;
-
- grid = gtk_grid_new ();
- label = gtk_label_new (result->comm);
- gtk_widget_set_direction (label, GTK_TEXT_DIR_LTR);
- gtk_widget_set_hexpand (label, TRUE);
- gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5);
- context = gtk_widget_get_style_context (label);
- gtk_style_context_add_class (context, "detail-comm");
- gtk_grid_attach (GTK_GRID (grid), label, rtl ? 1 : 0, 0, 1, 1);
-
- time = gl_util_timestamp_to_display (result->timestamp,
- priv->clock_format);
- label = gtk_label_new (time);
- gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5);
- gtk_label_set_selectable (GTK_LABEL (label), TRUE);
- context = gtk_widget_get_style_context (label);
- gtk_style_context_add_class (context, "detail-time");
- gtk_grid_attach (GTK_GRID (grid), label, rtl ? 0 : 1, 0, 1, 1);
- g_free (time);
-
- label = gtk_label_new (result->message);
- gtk_widget_set_direction (label, GTK_TEXT_DIR_LTR);
- gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5);
- gtk_label_set_line_wrap (GTK_LABEL (label), TRUE);
- gtk_label_set_selectable (GTK_LABEL (label), TRUE);
- context = gtk_widget_get_style_context (label);
- gtk_style_context_add_class (context, "detail-message");
- gtk_style_context_add_class (context, "event-monospace");
- gtk_grid_attach (GTK_GRID (grid), label, 0, 1, 2, 1);
-
- label = gtk_label_new (result->catalog);
- gtk_widget_set_direction (label, GTK_TEXT_DIR_LTR);
- gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5);
- gtk_label_set_selectable (GTK_LABEL (label), TRUE);
- context = gtk_widget_get_style_context (label);
- gtk_style_context_add_class (context, "detail-catalog");
- gtk_grid_attach (GTK_GRID (grid), label, 0, 2, 2, 1);
-
- gtk_widget_show_all (grid);
+ detail = gl_event_view_detail_new (result, priv->clock_format);
+
+ gtk_widget_show_all (detail);
+
stack = GTK_STACK (view);
- gtk_stack_add_named (stack, grid, "detail");
+ gtk_stack_add_named (stack, detail, "detail");
gl_event_view_set_mode (view, GL_EVENT_VIEW_MODE_DETAIL);
-
- return;
}
static GtkWidget *
diff --git a/src/gl-eventviewdetail.c b/src/gl-eventviewdetail.c
new file mode 100644
index 0000000..c514b6d
--- /dev/null
+++ b/src/gl-eventviewdetail.c
@@ -0,0 +1,207 @@
+/*
+ * GNOME Logs - View and search logs
+ * Copyright (C) 2013 Red Hat, Inc.
+ *
+ * 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 <http://www.gnu.org/licenses/>.
+ */
+
+#include "gl-eventviewdetail.h"
+
+#include "gl-enums.h"
+
+enum
+{
+ PROP_0,
+ PROP_CLOCK_FORMAT,
+ PROP_RESULT,
+ N_PROPERTIES
+};
+
+typedef struct
+{
+ GlJournalResult *result;
+ GlUtilClockFormat clock_format;
+} GlEventViewDetailPrivate;
+
+G_DEFINE_TYPE_WITH_PRIVATE (GlEventViewDetail, gl_event_view_detail, GTK_TYPE_BIN)
+
+static GParamSpec *obj_properties[N_PROPERTIES] = { NULL, };
+
+static void
+gl_event_view_detail_create_detail (GlEventViewDetail *detail)
+{
+ GlEventViewDetailPrivate *priv;
+ GlJournalResult *result;
+ gchar *time;
+ gboolean rtl;
+ GtkWidget *grid;
+ GtkWidget *label;
+ GtkStyleContext *context;
+
+ priv = gl_event_view_detail_get_instance_private (detail);
+
+ result = priv->result;
+
+ rtl = gtk_widget_get_default_direction () == GTK_TEXT_DIR_RTL;
+
+ grid = gtk_grid_new ();
+ label = gtk_label_new (result->comm);
+ gtk_widget_set_direction (label, GTK_TEXT_DIR_LTR);
+ gtk_widget_set_hexpand (label, TRUE);
+ gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5);
+ context = gtk_widget_get_style_context (label);
+ gtk_style_context_add_class (context, "detail-comm");
+ gtk_grid_attach (GTK_GRID (grid), label, rtl ? 1 : 0, 0, 1, 1);
+
+ time = gl_util_timestamp_to_display (result->timestamp,
+ priv->clock_format);
+ label = gtk_label_new (time);
+ gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5);
+ gtk_label_set_selectable (GTK_LABEL (label), TRUE);
+ context = gtk_widget_get_style_context (label);
+ gtk_style_context_add_class (context, "detail-time");
+ gtk_grid_attach (GTK_GRID (grid), label, rtl ? 0 : 1, 0, 1, 1);
+ g_free (time);
+
+ label = gtk_label_new (result->message);
+ gtk_widget_set_direction (label, GTK_TEXT_DIR_LTR);
+ gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5);
+ gtk_label_set_line_wrap (GTK_LABEL (label), TRUE);
+ gtk_label_set_selectable (GTK_LABEL (label), TRUE);
+ context = gtk_widget_get_style_context (label);
+ gtk_style_context_add_class (context, "detail-message");
+ gtk_style_context_add_class (context, "event-monospace");
+ gtk_grid_attach (GTK_GRID (grid), label, 0, 1, 2, 1);
+
+ label = gtk_label_new (result->catalog);
+ gtk_widget_set_direction (label, GTK_TEXT_DIR_LTR);
+ gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5);
+ gtk_label_set_selectable (GTK_LABEL (label), TRUE);
+ context = gtk_widget_get_style_context (label);
+ gtk_style_context_add_class (context, "detail-catalog");
+ gtk_grid_attach (GTK_GRID (grid), label, 0, 2, 2, 1);
+
+ gtk_widget_show_all (grid);
+
+ gtk_container_add (GTK_CONTAINER (detail), grid);
+}
+
+static void
+gl_event_view_detail_finalize (GObject *object)
+{
+ GlEventViewDetail *detail = GL_EVENT_VIEW_DETAIL (object);
+ GlEventViewDetailPrivate *priv = gl_event_view_detail_get_instance_private (detail);
+
+ g_clear_pointer (&priv->result, gl_journal_result_unref);
+}
+
+static void
+gl_event_view_detail_get_property (GObject *object,
+ guint prop_id,
+ GValue *value,
+ GParamSpec *pspec)
+{
+ GlEventViewDetail *detail = GL_EVENT_VIEW_DETAIL (object);
+ GlEventViewDetailPrivate *priv = gl_event_view_detail_get_instance_private (detail);
+
+ switch (prop_id)
+ {
+ case PROP_CLOCK_FORMAT:
+ g_value_set_enum (value, priv->clock_format);
+ break;
+ case PROP_RESULT:
+ g_value_set_boxed (value, priv->result);
+ break;
+ default:
+ G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
+ break;
+ }
+}
+
+static void
+gl_event_view_detail_set_property (GObject *object,
+ guint prop_id,
+ const GValue *value,
+ GParamSpec *pspec)
+{
+ GlEventViewDetail *detail = GL_EVENT_VIEW_DETAIL (object);
+ GlEventViewDetailPrivate *priv = gl_event_view_detail_get_instance_private (detail);
+
+ switch (prop_id)
+ {
+ case PROP_CLOCK_FORMAT:
+ priv->clock_format = g_value_get_enum (value);
+ break;
+ case PROP_RESULT:
+ priv->result = g_value_dup_boxed (value);
+ break;
+ default:
+ G_OBJECT_WARN_INVALID_PROPERTY_ID (object, prop_id, pspec);
+ break;
+ }
+}
+
+static void
+gl_event_view_detail_constructed (GObject *object)
+{
+ GlEventViewDetail *detail = GL_EVENT_VIEW_DETAIL (object);
+
+ /* contruct-only properties have already been set. */
+ gl_event_view_detail_create_detail (detail);
+
+ G_OBJECT_CLASS (gl_event_view_detail_parent_class)->constructed (object);
+}
+
+static void
+gl_event_view_detail_class_init (GlEventViewDetailClass *klass)
+{
+ GObjectClass *gobject_class = G_OBJECT_CLASS (klass);
+
+ gobject_class->constructed = gl_event_view_detail_constructed;
+ gobject_class->finalize = gl_event_view_detail_finalize;
+ gobject_class->get_property = gl_event_view_detail_get_property;
+ gobject_class->set_property = gl_event_view_detail_set_property;
+
+ obj_properties[PROP_CLOCK_FORMAT] = g_param_spec_enum ("clock-format", "Clock format",
+ "Format of the clock in which to show timestamps",
+ GL_TYPE_UTIL_CLOCK_FORMAT,
+ GL_UTIL_CLOCK_FORMAT_24HR,
+ G_PARAM_READWRITE |
+ G_PARAM_CONSTRUCT_ONLY |
+ G_PARAM_STATIC_STRINGS);
+
+ obj_properties[PROP_RESULT] = g_param_spec_boxed ("result", "Result",
+ "Journal query result for this detailed view",
+ GL_TYPE_JOURNAL_RESULT,
+ G_PARAM_READWRITE |
+ G_PARAM_CONSTRUCT_ONLY |
+ G_PARAM_STATIC_STRINGS);
+
+ g_object_class_install_properties (gobject_class, N_PROPERTIES,
+ obj_properties);
+}
+
+static void
+gl_event_view_detail_init (GlEventViewDetail *detail)
+{
+ /* See gl_event_view_detail_constructed (). */
+}
+
+GtkWidget *
+gl_event_view_detail_new (GlJournalResult *result,
+ GlUtilClockFormat clock_format)
+{
+ return g_object_new (GL_TYPE_EVENT_VIEW_DETAIL, "result", result,
+ "clock-format", clock_format, NULL);
+}
diff --git a/src/gl-eventviewdetail.h b/src/gl-eventviewdetail.h
new file mode 100644
index 0000000..b15d3bb
--- /dev/null
+++ b/src/gl-eventviewdetail.h
@@ -0,0 +1,49 @@
+/*
+ * GNOME Logs - View and search logs
+ * Copyright (C) 2013 Red Hat, Inc.
+ *
+ * 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 <http://www.gnu.org/licenses/>.
+ */
+
+#ifndef GL_EVENT_VIEW_DETAIL_H_
+#define GL_EVENT_VIEW_DETAIL_H_
+
+#include <gtk/gtk.h>
+
+G_BEGIN_DECLS
+
+#include "gl-journal.h"
+#include "gl-util.h"
+
+typedef struct
+{
+ /*< private >*/
+ GtkBin parent_instance;
+} GlEventViewDetail;
+
+typedef struct
+{
+ /*< private >*/
+ GtkBinClass parent_class;
+} GlEventViewDetailClass;
+
+#define GL_TYPE_EVENT_VIEW_DETAIL (gl_event_view_detail_get_type ())
+#define GL_EVENT_VIEW_DETAIL(object) (G_TYPE_CHECK_INSTANCE_CAST ((object), GL_TYPE_EVENT_VIEW_DETAIL,
GlEventViewDetail))
+
+GType gl_event_view_detail_get_type (void);
+GtkWidget * gl_event_view_detail_new (GlJournalResult *result, GlUtilClockFormat clock_format);
+
+G_END_DECLS
+
+#endif /* GL_EVENT_VIEW_DETAIL_H_ */
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]