[gnome-flashback/wip/segeiger/inputmethods: 5/6] Print available engine names and use timeout to change engine to german



commit 164671bf3aaacd459e9f04f197f6268d8fe34d48
Author: Sebastian Geiger <sbastig gmx net>
Date:   Tue Sep 15 00:41:25 2015 +0200

    Print available engine names and use timeout to change engine to german

 gnome-flashback/libinput-sources/gf-ibus-manager.c |    1 +
 .../libinput-sources/gf-input-sources.c            |   35 ++++++++++++++++++++
 2 files changed, 36 insertions(+), 0 deletions(-)
---
diff --git a/gnome-flashback/libinput-sources/gf-ibus-manager.c 
b/gnome-flashback/libinput-sources/gf-ibus-manager.c
index 9784142..d462d51 100644
--- a/gnome-flashback/libinput-sources/gf-ibus-manager.c
+++ b/gnome-flashback/libinput-sources/gf-ibus-manager.c
@@ -113,6 +113,7 @@ add_to_engines_cb (IBusEngineDesc *engineDescription,
                    GfIBusManager  *manager)
 {
   const char *name = ibus_engine_desc_get_name (engineDescription);
+  g_message ("EngineName: %s", name);
   g_hash_table_insert (manager->engines, (gpointer) name, engineDescription);
 }
 
diff --git a/gnome-flashback/libinput-sources/gf-input-sources.c 
b/gnome-flashback/libinput-sources/gf-input-sources.c
index 7dba453..c5f3b3a 100644
--- a/gnome-flashback/libinput-sources/gf-input-sources.c
+++ b/gnome-flashback/libinput-sources/gf-input-sources.c
@@ -90,15 +90,50 @@ gf_input_sources_class_init (GfInputSourcesClass *sources_class)
 }
 
 static void
+gf_callback (GObject *object, GAsyncResult *result, gpointer user_data)
+{
+  IBusBus *ibus;
+  g_return_if_fail (IBUS_IS_BUS (user_data));
+
+  ibus = IBUS_BUS (object);
+
+  if (result) {
+    GError *error;
+    gboolean success;
+    error = NULL;
+    success = ibus_bus_set_global_engine_async_finish (ibus, result, &error);
+    if (error) {
+      g_log ("gnome-flashback", G_LOG_LEVEL_ERROR, "Error changing engine: %s", error->message);
+      g_error_free (error);
+    }
+    g_message ("Success: %s", success ? "true" : "false");
+  }
+}
+
+static gboolean
+change_ime(gpointer user_data)
+{
+  GfIBusManager *manager;
+
+  manager = GF_IBUS_MANAGER (user_data);
+
+  gf_ibus_manager_set_engine (manager, "xkb:de::ger", gf_callback);
+  return G_SOURCE_REMOVE;
+};
+
+static void
 gf_input_sources_init (GfInputSources *input_sources)
 {
   input_sources->ibus_manager = gf_ibus_manager_new ();
   input_sources->input_source_manager = gf_input_source_manager_new (input_sources->ibus_manager);
 
+
   g_signal_connect(input_sources->ibus_manager, "ready", G_CALLBACK (ready_callback), input_sources);
   g_signal_connect(input_sources->ibus_manager, "properties-registered", G_CALLBACK (properties_registered), 
input_sources);
   g_signal_connect(input_sources->ibus_manager, "property-updated", G_CALLBACK (property_updated), 
input_sources);
   g_signal_connect(input_sources->ibus_manager, "set-content-type", G_CALLBACK (set_content_type), 
input_sources);
+
+  g_timeout_add (2000, change_ime, input_sources->ibus_manager);
 }
 
 GfInputSources *


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