Add libxklavier option to eekboard-xml.
This commit is contained in:
@ -17,26 +17,42 @@
|
||||
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
|
||||
* 02110-1301 USA
|
||||
*/
|
||||
#include <stdlib.h>
|
||||
|
||||
#ifdef HAVE_CONFIG_H
|
||||
#include "config.h"
|
||||
#endif /* HAVE_CONFIG_H */
|
||||
|
||||
#include <string.h>
|
||||
#include <stdlib.h>
|
||||
#include <gdk/gdkx.h>
|
||||
|
||||
#include "eek/eek-xml.h"
|
||||
#include "eek/eek-xkl.h"
|
||||
#include "eek/eek-gtk.h"
|
||||
|
||||
#include "xklutil.h"
|
||||
|
||||
#define BUFSIZE 8192
|
||||
|
||||
static gchar *opt_load = NULL;
|
||||
static gboolean opt_dump = FALSE;
|
||||
static gchar *opt_model = NULL;
|
||||
static gchar *opt_layouts = NULL;
|
||||
static gchar *opt_options = NULL;
|
||||
static gchar *opt_list = NULL;
|
||||
|
||||
static const GOptionEntry options[] = {
|
||||
{"load", 'l', 0, G_OPTION_ARG_STRING, &opt_load,
|
||||
"Show the keyboard loaded from an XML file"},
|
||||
{"dump", 'd', 0, G_OPTION_ARG_NONE, &opt_dump,
|
||||
"Dump the current layout as XML"},
|
||||
{"list", 'L', 0, G_OPTION_ARG_STRING, &opt_list,
|
||||
"List configuration items for given spec"},
|
||||
{"model", '\0', 0, G_OPTION_ARG_STRING, &opt_model,
|
||||
"Specify model"},
|
||||
{"layouts", '\0', 0, G_OPTION_ARG_STRING, &opt_layouts,
|
||||
"Specify layouts"},
|
||||
{"options", '\0', 0, G_OPTION_ARG_STRING, &opt_options,
|
||||
"Specify options"},
|
||||
{NULL}
|
||||
};
|
||||
|
||||
@ -46,6 +62,15 @@ on_destroy (gpointer user_data)
|
||||
gtk_main_quit ();
|
||||
}
|
||||
|
||||
static void
|
||||
print_item (gpointer data,
|
||||
gpointer user_data)
|
||||
{
|
||||
XklConfigItem *item = data;
|
||||
g_assert (item);
|
||||
printf ("%s: %s\n", item->name, item->description);
|
||||
}
|
||||
|
||||
int
|
||||
main (int argc, char **argv)
|
||||
{
|
||||
@ -106,6 +131,26 @@ main (int argc, char **argv)
|
||||
|
||||
output = g_string_sized_new (BUFSIZE);
|
||||
layout = eek_xkl_layout_new ();
|
||||
|
||||
if (opt_model)
|
||||
eek_xkl_layout_set_model (EEK_XKL_LAYOUT(layout), opt_model);
|
||||
|
||||
if (opt_layouts) {
|
||||
XklConfigRec *rec;
|
||||
|
||||
rec = eekboard_xkl_config_rec_new_from_string (opt_layouts);
|
||||
eek_xkl_layout_set_layouts (EEK_XKL_LAYOUT(layout), rec->layouts);
|
||||
eek_xkl_layout_set_variants (EEK_XKL_LAYOUT(layout), rec->variants);
|
||||
g_object_unref (rec);
|
||||
}
|
||||
|
||||
if (opt_options) {
|
||||
gchar **options;
|
||||
options = g_strsplit (opt_options, ",", -1);
|
||||
eek_xkl_layout_set_options (EEK_XKL_LAYOUT(layout), options);
|
||||
g_strfreev (options);
|
||||
}
|
||||
|
||||
keyboard = eek_keyboard_new (layout, 640, 480);
|
||||
g_object_unref (layout);
|
||||
eek_keyboard_output (keyboard, output, 0);
|
||||
@ -113,8 +158,43 @@ main (int argc, char **argv)
|
||||
fwrite (output->str, sizeof(gchar), output->len, stdout);
|
||||
g_string_free (output, TRUE);
|
||||
exit (0);
|
||||
} else if (opt_list) {
|
||||
GdkDisplay *display;
|
||||
XklEngine *engine;
|
||||
XklConfigRegistry *registry;
|
||||
GSList *items = NULL, *head;
|
||||
|
||||
display = gdk_display_get_default ();
|
||||
engine = xkl_engine_get_instance (GDK_DISPLAY_XDISPLAY(display));
|
||||
registry = xkl_config_registry_get_instance (engine);
|
||||
xkl_config_registry_load (registry, FALSE);
|
||||
|
||||
if (g_strcmp0 (opt_list, "model") == 0) {
|
||||
items = eekboard_xkl_list_models (registry);
|
||||
} else if (g_strcmp0 (opt_list, "layout") == 0) {
|
||||
items = eekboard_xkl_list_layouts (registry);
|
||||
} else if (g_strcmp0 (opt_list, "option-group") == 0) {
|
||||
items = eekboard_xkl_list_option_groups (registry);
|
||||
} else if (g_str_has_prefix (opt_list, "layout-variant-")) {
|
||||
items = eekboard_xkl_list_layout_variants
|
||||
(registry,
|
||||
opt_list + strlen ("layout-variant-"));
|
||||
} else if (g_str_has_prefix (opt_list, "option-")) {
|
||||
items = eekboard_xkl_list_options
|
||||
(registry,
|
||||
opt_list + strlen ("option-"));
|
||||
} else {
|
||||
g_printerr ("Unknown list spec \"%s\"\n", opt_list);
|
||||
}
|
||||
g_slist_foreach (items, print_item, NULL);
|
||||
for (head = items; head; head = g_slist_next (head))
|
||||
g_object_unref (head->data);
|
||||
g_slist_free (items);
|
||||
g_object_unref (engine);
|
||||
g_object_unref (registry);
|
||||
exit (0);
|
||||
} else {
|
||||
g_printerr ("Specify -l or -d option\n");
|
||||
g_printerr ("Specify -l, -d, or -L option\n");
|
||||
exit (1);
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user