[gnome-flashback/wip/segeiger/statusicon: 3/4] input-sources: add signal current-source-changed to GfInputSourceManager



commit 54fa5bdb6c344742942f4ae5ca36212fc3b9a028
Author: Sebastian Geiger <sbastig gmx net>
Date:   Wed Sep 30 14:53:45 2015 +0200

    input-sources: add signal current-source-changed to GfInputSourceManager

 .../libinput-sources/gf-input-source-manager.c     |   33 ++++++++++++++++++++
 .../libinput-sources/gf-input-source-manager.h     |    7 +++-
 2 files changed, 38 insertions(+), 2 deletions(-)
---
diff --git a/gnome-flashback/libinput-sources/gf-input-source-manager.c 
b/gnome-flashback/libinput-sources/gf-input-source-manager.c
index 943413d..552d905 100644
--- a/gnome-flashback/libinput-sources/gf-input-source-manager.c
+++ b/gnome-flashback/libinput-sources/gf-input-source-manager.c
@@ -73,11 +73,14 @@ struct _GfInputSourceManager
   GList                 *mru_sources_backup;
 
   GtkWidget             *popup;
+
+  GfInputSource         *current_source;
 };
 
 enum
 {
   SIGNAL_SOURCES_CHANGED,
+  SIGNAL_CURRENT_SOURCE_CHANGED,
 
   LAST_SIGNAL
 };
@@ -442,6 +445,7 @@ current_input_source_changed (GfInputSourceManager *manager,
                               GfInputSource        *new_source)
 {
   GList *l;
+  GfInputSource *old_source;
 
   for (l = manager->mru_sources; l != NULL; l = g_list_next (l))
     {
@@ -457,6 +461,22 @@ current_input_source_changed (GfInputSourceManager *manager,
           break;
         }
     }
+
+  old_source = manager->current_source;
+  manager->current_source = new_source;
+
+  /* When we reach this function, the reference count of
+   * manager->current_source which is now the old_source has already been
+   * reduced. To prevent it from reaching zero before we can
+   * emit the signal, we increase the reference count for current_source and
+   * unreference it, after we have emitted the signal. */
+  g_object_ref (manager->current_source);
+
+  if (old_source != NULL) {
+    g_signal_emit (manager, signals[SIGNAL_CURRENT_SOURCE_CHANGED], 0,
+                   old_source);
+    g_object_unref (old_source);
+  }
 }
 
 static void
@@ -911,6 +931,8 @@ gf_input_source_manager_dispose (GObject *object)
 
   g_clear_object (&manager->keyboard_manager);
 
+  g_clear_object (&manager->current_source);
+
   if (manager->input_sources != 0)
     {
       g_hash_table_destroy (manager->input_sources);
@@ -1004,6 +1026,11 @@ gf_input_source_manager_class_init (GfInputSourceManagerClass *manager_class)
     g_signal_new ("sources-changed", G_TYPE_FROM_CLASS (manager_class),
                   G_SIGNAL_RUN_LAST, 0, NULL, NULL, NULL, G_TYPE_NONE, 0);
 
+  signals[SIGNAL_CURRENT_SOURCE_CHANGED] =
+      g_signal_new ("current-source-changed", G_TYPE_FROM_CLASS (manager_class),
+                    G_SIGNAL_RUN_LAST, 0, NULL, NULL, NULL, G_TYPE_NONE, 1,
+                    GF_TYPE_INPUT_SOURCE);
+
   properties[PROP_IBUS_MANAGER] =
     g_param_spec_object ("ibus-manager", "IBus Manager",
                          "An instance of GfIBusManager",
@@ -1043,3 +1070,9 @@ gf_input_source_manager_reload (GfInputSourceManager *manager)
 
   sources_changed_cb (manager->settings, manager);
 }
+
+GfInputSource *gf_input_source_manager_get_current_source (
+    GfInputSourceManager *manager)
+{
+  return manager->current_source;
+}
diff --git a/gnome-flashback/libinput-sources/gf-input-source-manager.h 
b/gnome-flashback/libinput-sources/gf-input-source-manager.h
index 73dddde..67e87ae 100644
--- a/gnome-flashback/libinput-sources/gf-input-source-manager.h
+++ b/gnome-flashback/libinput-sources/gf-input-source-manager.h
@@ -20,13 +20,16 @@
 
 #include <glib-object.h>
 #include "gf-ibus-manager.h"
+#include "gf-input-source.h"
 
 #define GF_TYPE_INPUT_SOURCE_MANAGER gf_input_source_manager_get_type ()
 G_DECLARE_FINAL_TYPE (GfInputSourceManager, gf_input_source_manager,
                       GF, INPUT_SOURCE_MANAGER, GObject)
 
-GfInputSourceManager *gf_input_source_manager_new    (GfIBusManager        *manager);
+GfInputSourceManager *gf_input_source_manager_new                (GfIBusManager        *manager);
 
-void                  gf_input_source_manager_reload (GfInputSourceManager *manager);
+void                  gf_input_source_manager_reload             (GfInputSourceManager *manager);
+
+GfInputSource        *gf_input_source_manager_get_current_source (GfInputSourceManager *manager);
 
 #endif


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