From 5218dd6a342830c5001316fd5057eadab840420d Mon Sep 17 00:00:00 2001 From: Benjamin Otte Date: Thu, 23 Aug 2018 21:07:36 +0200 Subject: shortcuttrigger: Add gtk_shortcut_triger_new_parse_string() And hook it up into the GtkBuilder infrastructure. --- gtk/gtkbuilder.c | 20 +++++++++++++++++++- 1 file changed, 19 insertions(+), 1 deletion(-) (limited to 'gtk/gtkbuilder.c') diff --git a/gtk/gtkbuilder.c b/gtk/gtkbuilder.c index ba3f367ddc..e841be2ea1 100644 --- a/gtk/gtkbuilder.c +++ b/gtk/gtkbuilder.c @@ -219,12 +219,14 @@ #include "gtkbuilderscopeprivate.h" #include "gtkdebug.h" #include "gtkmain.h" +#include "gtkicontheme.h" #include "gtkintl.h" #include "gtkprivate.h" +#include "gtkshortcuttrigger.h" +#include "gtktestutils.h" #include "gtktypebuiltins.h" #include "gtkicontheme.h" #include "gtkiconthemeprivate.h" -#include "gdkpixbufutilsprivate.h" static void gtk_builder_finalize (GObject *object); static void gtk_builder_set_property (GObject *object, @@ -2092,6 +2094,22 @@ gtk_builder_value_from_string_type (GtkBuilder *builder, ret = FALSE; } } + else if (G_VALUE_HOLDS (value, GTK_TYPE_SHORTCUT_TRIGGER)) + { + GtkShortcutTrigger *trigger = gtk_shortcut_trigger_parse_string (string); + + if (trigger) + g_value_take_boxed (value, trigger); + else + { + g_set_error (error, + GTK_BUILDER_ERROR, + GTK_BUILDER_ERROR_INVALID_VALUE, + "Could not parse shortcut trigger '%s'", + string); + ret = FALSE; + } + } else if (G_VALUE_HOLDS (value, G_TYPE_STRV)) { gchar **vector = g_strsplit (string, "\n", 0); -- cgit v1.2.1