[gnome-flashback/wip/segeiger/inputmethods: 6/6] input-sources: Partial implementation for GfInputSourceManager



commit aa9179becb7a17d72dc14ae6002300e34d3a2cd1
Author: Sebastian Geiger <sbastig gmx net>
Date:   Sat Sep 19 18:37:18 2015 +0200

    input-sources: Partial implementation for GfInputSourceManager

 .../libinput-sources/gf-input-source-manager.c     |  218 +++++++++++++++++++-
 .../libinput-sources/gf-input-source-manager.h     |   10 +-
 gnome-flashback/libinput-sources/gf-input-source.c |    6 +
 gnome-flashback/libinput-sources/gf-input-source.h |   12 +-
 4 files changed, 238 insertions(+), 8 deletions(-)
---
diff --git a/gnome-flashback/libinput-sources/gf-input-source-manager.c 
b/gnome-flashback/libinput-sources/gf-input-source-manager.c
index e070c8d..c64547a 100644
--- a/gnome-flashback/libinput-sources/gf-input-source-manager.c
+++ b/gnome-flashback/libinput-sources/gf-input-source-manager.c
@@ -22,11 +22,13 @@
 #include <glib/gi18n.h>
 #include <libcommon/gf-keybindings.h>
 
+#include "gf-ibus-manager.h"
+#include "gf-input-source.h"
 #include "gf-input-source-manager.h"
 #include "gf-input-source-settings.h"
-#include "gf-ibus-manager.h"
 #include "gf-keyboard-manager.h"
 
+
 #define DESKTOP_WM_KEYBINDINGS_SCHEMA "org.gnome.desktop.wm.keybindings"
 
 #define KEY_SWITCH_INPUT_SOURCE "switch-input-source"
@@ -59,8 +61,29 @@ struct _GfInputSourceManager
 
   GfKeyboardManager     *keyboard_manager;
 
+  gboolean               ibusReady;
   GfIBusManager         *ibus_manager;
   gboolean               disable_ibus;
+
+  /**
+   * All valid input sources currently in the GSettings KEY_INPUT_SOURCES list
+   * indexed by their index there
+   */
+  GHashTable            *input_sources;
+
+  /**
+   * All valid input sources currently in the GSettings KEY_INPUT_SOURCES list
+   * of type INPUT_SOURCE_TYPE_IBUS indexed by their IBus ID.
+   */
+  GHashTable *ibus_sources;
+
+  /**
+   * All valid input sources currently in the GSettings KEY_INPUT_SOURCES
+   * list ordered
+   */
+  GList *mruSources;
+
+  GfInputSource *currentSource;
 };
 
 enum
@@ -185,6 +208,48 @@ accelerator_activated_cb (GfKeybindings *keybindings,
                           GVariant      *parameters,
                           gpointer       user_data)
 {
+  GfInputSourceManager *manager;
+  GfInputSource *input_source;
+  GList *source_indexes;
+  GList *source_values;
+
+  manager = GF_INPUT_SOURCE_MANAGER (user_data);
+  source_indexes = g_hash_table_get_keys (manager->input_sources);
+  source_values = g_hash_table_get_values (manager->input_sources);
+
+  if (g_list_length (source_indexes) == 0)
+    {
+      //gf_keyboard_manager_release_keyboard (manager->keyboard_manager);
+      return;
+    }
+
+  input_source = gf_input_source_manager_get_current_source (manager);
+
+  if (input_source == NULL)
+    {
+      input_source = source_values->data;
+    }
+
+  if (action == manager->switch_source_action)
+    {
+      GList *next_source_value = source_values;
+      while (next_source_value != NULL && next_source_value->data == NULL)
+        {
+          next_source_value = next_source_value->next;
+        }
+      input_source = next_source_value->data;
+    }
+  else
+    {
+      GList *prev_source_value = source_values;
+      while (prev_source_value->data == NULL && prev_source_value->prev != NULL)
+      {
+        prev_source_value = prev_source_value->prev;
+      }
+      input_source = prev_source_value->data;
+    }
+
+  gf_input_source_activate (input_source);
 }
 
 static void
@@ -413,6 +478,107 @@ gf_input_source_manager_dispose (GObject *object)
 }
 
 static void
+gf_input_source_manager_ibus_ready_callback (GfIBusManager* iBusManager, gboolean ready)
+{
+}
+
+static void
+gf_input_source_manager_modifiers_switch ()
+{
+
+}
+
+static void
+gf_input_source_manager_switch_input_source (void)
+{
+
+}
+
+static void
+gf_input_source_manager_keyboard_options_changed (void)
+{
+
+}
+
+static void
+gf_input_source_manager_current_input_source_changed (void)
+{
+
+}
+
+static void
+gf_input_source_manager_activate_input_source (void)
+{
+
+}
+
+static void
+gf_input_source_manager_input_sources_changed (void)
+{
+
+}
+
+static void
+gf_input_source_manager_make_engine_short_name (void)
+{
+
+}
+
+static void
+gf_input_source_manager_ibus_properties_registered (void)
+{
+
+}
+
+static void
+gf_input_source_manager_ibus_property_updated (void)
+{
+
+}
+
+static void
+gf_input_source_manager_update_sub_property (void)
+{
+
+}
+
+static void
+gf_input_source_manager_ibus_set_content_type (void)
+{
+
+}
+
+static void
+gf_input_source_manager_get_new_input_source (void)
+{
+
+}
+
+static void
+gf_input_source_manager_get_current_window (void)
+{
+
+}
+
+static void
+gf_input_source_manager_set_per_window_input_source (void)
+{
+
+}
+
+static void
+gf_input_source_manager_sources_per_window_changed (void)
+{
+
+}
+
+static void
+gf_input_source_manager_change_per_window_source (void)
+{
+
+}
+
+static void
 gf_input_source_manager_set_property (GObject      *object,
                                       guint         property_id,
                                       const GValue *value,
@@ -457,6 +623,36 @@ gf_input_source_manager_get_property (GObject    *object,
 }
 
 static void
+gf_input_source_manager_constructed (GObject *object)
+{
+  GfInputSourceManager *manager;
+
+  G_OBJECT_CLASS (gf_input_source_manager_parent_class)->constructed (object);
+
+  manager = GF_INPUT_SOURCE_MANAGER (object);
+
+  g_signal_connect (manager->ibus_manager,
+                    "ready",
+                    G_CALLBACK (gf_input_source_manager_ibus_ready_callback),
+                    manager);
+
+  g_signal_connect (manager->ibus_manager,
+                    "properties-registered",
+                    G_CALLBACK (gf_input_source_manager_ibus_properties_registered),
+                    manager);
+
+  g_signal_connect (manager->ibus_manager,
+                    "property-updated",
+                    G_CALLBACK (gf_input_source_manager_ibus_property_updated),
+                    manager);
+
+  g_signal_connect (manager->ibus_manager,
+                    "set-content-type",
+                    G_CALLBACK (gf_input_source_manager_ibus_set_content_type),
+                    manager);
+}
+
+static void
 gf_input_source_manager_class_init (GfInputSourceManagerClass *manager_class)
 {
   GObjectClass *object_class;
@@ -466,6 +662,7 @@ gf_input_source_manager_class_init (GfInputSourceManagerClass *manager_class)
   object_class->dispose = gf_input_source_manager_dispose;
   object_class->get_property = gf_input_source_manager_get_property;
   object_class->set_property = gf_input_source_manager_set_property;
+  object_class->constructed = gf_input_source_manager_constructed;
 
   properties[PROP_IBUS_MANAGER] =
     g_param_spec_object ("ibus-manager", "IBus Manager",
@@ -484,11 +681,15 @@ gf_input_source_manager_init (GfInputSourceManager *manager)
 
   keybindings_init (manager);
   input_source_settings_init (manager);
+  manager->input_sources = g_hash_table_new (g_str_hash, g_str_equal);
+  manager->ibus_sources = g_hash_table_new (g_str_hash, g_str_equal);
 }
 
+
 GfInputSourceManager *
 gf_input_source_manager_new (GfIBusManager *ibus_manager)
 {
+  g_return_val_if_fail (ibus_manager, NULL);
   return g_object_new (GF_TYPE_INPUT_SOURCE_MANAGER,
                        "ibus-manager", ibus_manager,
                        NULL);
@@ -506,3 +707,18 @@ 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->currentSource;
+}
+
+/**
+ * Returns: A #GHashTable of #GfInputSource objects
+ */
+GHashTable *
+gf_input_source_manager_input_sources (GfInputSourceManager *manager)
+{
+    return manager->input_sources;
+}
diff --git a/gnome-flashback/libinput-sources/gf-input-source-manager.h 
b/gnome-flashback/libinput-sources/gf-input-source-manager.h
index 73dddde..9441991 100644
--- a/gnome-flashback/libinput-sources/gf-input-source-manager.h
+++ b/gnome-flashback/libinput-sources/gf-input-source-manager.h
@@ -19,14 +19,20 @@
 #define GF_INPUT_SOURCE_MANAGER_H
 
 #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);
+
+GfInputSource        *gf_input_source_manager_get_current_source (GfInputSourceManager *manager);
 
-void                  gf_input_source_manager_reload (GfInputSourceManager *manager);
+GHashTable           *gf_input_source_manager_input_sources      (GfInputSourceManager *manager);
 
 #endif
diff --git a/gnome-flashback/libinput-sources/gf-input-source.c 
b/gnome-flashback/libinput-sources/gf-input-source.c
index b912ac4..ec9ad12 100644
--- a/gnome-flashback/libinput-sources/gf-input-source.c
+++ b/gnome-flashback/libinput-sources/gf-input-source.c
@@ -265,3 +265,9 @@ gf_input_source_new (GfIBusManager *ibus_manager,
                        "index", index,
                        NULL);
 }
+
+void
+gf_input_source_activate (GfInputSource *source)
+{
+  g_signal_emit (source, SIGNAL_ACTIVATE, 0);
+}
diff --git a/gnome-flashback/libinput-sources/gf-input-source.h 
b/gnome-flashback/libinput-sources/gf-input-source.h
index a11291c..8bc8264 100644
--- a/gnome-flashback/libinput-sources/gf-input-source.h
+++ b/gnome-flashback/libinput-sources/gf-input-source.h
@@ -24,10 +24,12 @@
 #define GF_TYPE_INPUT_SOURCE gf_input_source_get_type ()
 G_DECLARE_FINAL_TYPE (GfInputSource, gf_input_source, GF, INPUT_SOURCE, GObject)
 
-GfInputSource *gf_input_source_new (GfIBusManager *ibus_manager,
-                                    const char    *id,
-                                    const char    *display_name,
-                                    const char    *short_name,
-                                    guint          index);
+GfInputSource *gf_input_source_new      (GfIBusManager     *ibus_manager,
+                                         const char        *id,
+                                         const char        *display_name,
+                                         const char        *short_name,
+                                         guint              index);
+
+void           gf_input_source_activate (GfInputSource     *source);
 
 #endif


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