[gtk/wip/baedert/for-master: 54/58] widget: Refactor gtk_widget_class_set_template()




commit 699adb0b1063d71d226e99a4dd387aca8a31cb9d
Author: Timm Bäder <mail baedert org>
Date:   Sun Jan 3 08:45:30 2021 +0100

    widget: Refactor gtk_widget_class_set_template()
    
    Don't call gbytes_get_data/get_size so often and exit early if the given
    bytes is already precompiled.

 gtk/gtkwidget.c | 33 +++++++++++++++++----------------
 1 file changed, 17 insertions(+), 16 deletions(-)
---
diff --git a/gtk/gtkwidget.c b/gtk/gtkwidget.c
index 98ff2a01e4..239f7735e8 100644
--- a/gtk/gtkwidget.c
+++ b/gtk/gtkwidget.c
@@ -10852,35 +10852,36 @@ out:
  * in the widget’s instance initializer.
  */
 void
-gtk_widget_class_set_template (GtkWidgetClass    *widget_class,
-                               GBytes            *template_bytes)
+gtk_widget_class_set_template (GtkWidgetClass *widget_class,
+                               GBytes         *template_bytes)
 {
+  GError *error = NULL;
   GBytes *data = NULL;
+  gconstpointer bytes_data;
+  gsize bytes_size;
 
   g_return_if_fail (GTK_IS_WIDGET_CLASS (widget_class));
   g_return_if_fail (widget_class->priv->template == NULL);
   g_return_if_fail (template_bytes != NULL);
 
   widget_class->priv->template = g_slice_new0 (GtkWidgetTemplate);
+  bytes_data = g_bytes_get_data (template_bytes, &bytes_size);
 
-  if (!_gtk_buildable_parser_is_precompiled (g_bytes_get_data (template_bytes, NULL), g_bytes_get_size 
(template_bytes)))
+  if (_gtk_buildable_parser_is_precompiled (bytes_data, bytes_size))
     {
-      GError *error = NULL;
+      widget_class->priv->template->data = g_bytes_ref (template_bytes);
+      return;
+    }
 
-      data = _gtk_buildable_parser_precompile (g_bytes_get_data (template_bytes, NULL),
-                                               g_bytes_get_size (template_bytes),
-                                               &error);
-      if (data == NULL)
-        {
-          g_warning ("Failed to precompile template for class %s: %s", G_OBJECT_CLASS_NAME (widget_class), 
error->message);
-          g_error_free (error);
-        }
+  data = _gtk_buildable_parser_precompile (bytes_data, bytes_size, &error);
+  if (data == NULL)
+    {
+      g_warning ("Failed to precompile template for class %s: %s", G_OBJECT_CLASS_NAME (widget_class), 
error->message);
+      g_error_free (error);
+      return;
     }
 
-  if (data)
-    widget_class->priv->template->data = data;
-  else
-    widget_class->priv->template->data = g_bytes_ref (template_bytes);
+  widget_class->priv->template->data = data;
 }
 
 /**


[Date Prev][Date Next]   [Thread Prev][Thread Next]   [Thread Index] [Date Index] [Author Index]