Add French and German keymaps to build, add failsafe keymap, parse layout parameter, cleanup contributed keymaps, add missing declarations.

This commit is contained in:
Michael Jumper 2013-03-29 13:08:14 -07:00
parent b6effd3d4f
commit 7ba047f5a8
7 changed files with 136 additions and 34 deletions

View File

@ -43,20 +43,22 @@ lib_LTLIBRARIES = libguac-client-rdp.la
freerdp_LTLIBRARIES = guac_rdpsnd.la freerdp_LTLIBRARIES = guac_rdpsnd.la
libguac_client_rdp_la_SOURCES = \ libguac_client_rdp_la_SOURCES = \
$(OGG_SOURCES) \ $(OGG_SOURCES) \
src/audio.c \ src/audio.c \
src/client.c \ src/client.c \
src/default_pointer.c \ src/default_pointer.c \
src/guac_handlers.c \ src/guac_handlers.c \
src/rdp_bitmap.c \ src/rdp_bitmap.c \
src/rdp_cliprdr.c \ src/rdp_cliprdr.c \
src/rdp_gdi.c \ src/rdp_gdi.c \
src/rdp_glyph.c \ src/rdp_glyph.c \
src/rdp_keymap_base.c \ src/rdp_keymap_base.c \
src/rdp_keymap.c \ src/rdp_keymap.c \
src/rdp_keymap_de_de.c \ src/rdp_keymap_de_de.c \
src/rdp_keymap_en_us.c \ src/rdp_keymap_failsafe.c \
src/rdp_pointer.c \ src/rdp_keymap_fr_fr.c \
src/rdp_keymap_en_us.c \
src/rdp_pointer.c \
src/wav_encoder.c src/wav_encoder.c
guac_rdpsnd_la_SOURCES = \ guac_rdpsnd_la_SOURCES = \

View File

@ -122,17 +122,27 @@ typedef guac_rdp_keysym_desc guac_rdp_static_keymap[256][256];
typedef int guac_rdp_keysym_state_map[256][256]; typedef int guac_rdp_keysym_state_map[256][256];
/** /**
* Map of X11 keysyms to RDP scancodes (US English). * US English keymap.
*/ */
extern const guac_rdp_keymap guac_rdp_keymap_en_us; extern const guac_rdp_keymap guac_rdp_keymap_en_us;
/** /**
* Map of X11 keysyms to RDP scancodes (German). * German keymap.
*/ */
extern const guac_rdp_keymap guac_rdp_keymap_de_de; extern const guac_rdp_keymap guac_rdp_keymap_de_de;
/** /**
* Map of X11 keysyms to RDP scancodes (common non-printable keys). * French keymap.
*/
extern const guac_rdp_keymap guac_rdp_keymap_fr_fr;
/**
* Failsafe (Unicode events for all printable characters) keymap.
*/
extern const guac_rdp_keymap guac_rdp_keymap_failsafe;
/**
* Common, base keymap for non-printable keys.
*/ */
extern const guac_rdp_keymap guac_rdp_keymap_base; extern const guac_rdp_keymap guac_rdp_keymap_base;
@ -172,6 +182,16 @@ extern const int GUAC_KEYSYMS_ALT[];
*/ */
extern const int GUAC_KEYSYMS_ALL_ALT[]; extern const int GUAC_KEYSYMS_ALL_ALT[];
/**
* Keysym string containing both "alt" keys.
*/
extern const int GUAC_KEYSYMS_ALL_ALT[];
/**
* Keysym string containing the left "alt" and left "ctrl" keys
*/
extern const int GUAC_KEYSYMS_CTRL_ALT[];
/** /**
* Keysym string containing all modifier keys. * Keysym string containing all modifier keys.
*/ */
@ -180,7 +200,7 @@ extern const int GUAC_KEYSYMS_ALL_MODIFIERS[];
/** /**
* NULL-terminated array of all keymaps. * NULL-terminated array of all keymaps.
*/ */
extern const guac_rpd_keymap* GUAC_KEYMAPS[]; extern const guac_rdp_keymap* GUAC_KEYMAPS[];
#endif #endif

View File

@ -527,16 +527,37 @@ int guac_client_init(guac_client* client, int argc, char** argv) {
/* US English Qwerty */ /* US English Qwerty */
if (strcmp("en-us-qwerty", argv[IDX_LAYOUT]) == 0) if (strcmp("en-us-qwerty", argv[IDX_LAYOUT]) == 0)
chosen_keymap = &rdp_guac_keymap_en_us; chosen_keymap = &guac_rdp_keymap_en_us;
/* US English Qwerty */ /* German Qwertz */
if (strcmp("en-us-qwerty", argv[IDX_LAYOUT]) == 0) else if (strcmp("de-de-qwertz", argv[IDX_LAYOUT]) == 0)
chosen_keymap = &rdp_guac_keymap_en_us; chosen_keymap = &guac_rdp_keymap_de_de;
/* French Azerty */
else if (strcmp("fr-fr-azerty", argv[IDX_LAYOUT]) == 0)
chosen_keymap = &guac_rdp_keymap_fr_fr;
/* Failsafe (Unicode) keymap */
else if (strcmp("failsafe", argv[IDX_LAYOUT]) == 0)
chosen_keymap = &guac_rdp_keymap_failsafe;
/* If keymap unknown, resort to failsafe */
else {
guac_client_log_error(client,
"Unknown layout \"%s\". Using the failsafe layout instead.",
argv[IDX_LAYOUT]);
chosen_keymap = &guac_rdp_keymap_failsafe;
}
else
chosen_keymap = &rdp_guac_keymap_en_us;
} }
/* If no keymap requested, assume US */
else
chosen_keymap = &guac_rdp_keymap_en_us;
/* Load keymap into client */ /* Load keymap into client */
__guac_rdp_client_load_keymap(client, chosen_keymap); __guac_rdp_client_load_keymap(client, chosen_keymap);

View File

@ -46,6 +46,8 @@ const int GUAC_KEYSYMS_ALL_CTRL[] = {0xFFE3, 0xFFE4, 0};
const int GUAC_KEYSYMS_ALT[] = {0xFFE9, 0}; const int GUAC_KEYSYMS_ALT[] = {0xFFE9, 0};
const int GUAC_KEYSYMS_ALL_ALT[] = {0xFFE9, 0xFFEA, 0}; const int GUAC_KEYSYMS_ALL_ALT[] = {0xFFE9, 0xFFEA, 0};
const int GUAC_KEYSYMS_CTRL_ALT[] = {0xFFE3, 0xFFE9, 0};
const int GUAC_KEYSYMS_ALL_MODIFIERS[] = { const int GUAC_KEYSYMS_ALL_MODIFIERS[] = {
0xFFE1, 0xFFE2, /* Left and right shift */ 0xFFE1, 0xFFE2, /* Left and right shift */
0xFFE3, 0xFFE4, /* Left and right control */ 0xFFE3, 0xFFE4, /* Left and right control */

View File

@ -0,0 +1,63 @@
/* ***** BEGIN LICENSE BLOCK *****
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
*
* The contents of this file are subject to the Mozilla Public License Version
* 1.1 (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
* http://www.mozilla.org/MPL/
*
* Software distributed under the License is distributed on an "AS IS" basis,
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
* for the specific language governing rights and limitations under the
* License.
*
* The Original Code is libguac-client-rdp.
*
* The Initial Developer of the Original Code is
* Michael Jumper.
* Portions created by the Initial Developer are Copyright (C) 2011
* the Initial Developer. All Rights Reserved.
*
* Contributor(s):
*
* Alternatively, the contents of this file may be used under the terms of
* either the GNU General Public License Version 2 or later (the "GPL"), or
* the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
* in which case the provisions of the GPL or the LGPL are applicable instead
* of those above. If you wish to allow use of your version of this file only
* under the terms of either the GPL or the LGPL, and not to allow others to
* use your version of this file under the terms of the MPL, indicate your
* decision by deleting the provisions above and replace them with the notice
* and other provisions required by the GPL or the LGPL. If you do not delete
* the provisions above, a recipient may use your version of this file under
* the terms of any one of the MPL, the GPL or the LGPL.
*
* ***** END LICENSE BLOCK ***** */
#include <freerdp/input.h>
#ifdef HAVE_FREERDP_LOCALE_KEYBOARD_H
#include <freerdp/locale/keyboard.h>
#else
#include <freerdp/kbd/layouts.h>
#endif
#include "rdp_keymap.h"
static guac_rdp_keysym_desc __guac_rdp_keymap_mapping[] = {
{0}
};
const guac_rdp_keymap guac_rdp_keymap_failsafe = {
.name = "failsafe",
.parent = &guac_rdp_keymap_base,
.mapping = __guac_rdp_keymap_mapping,
.freerdp_keyboard_layout = KBD_US
};

View File

@ -48,12 +48,6 @@
#include "rdp_keymap.h" #include "rdp_keymap.h"
/*
This array is order by .keysym
the .keysym is the ASCII value
the .scancode the key scancode
*/
static guac_rdp_keysym_desc __guac_rdp_keymap_mapping[] = { static guac_rdp_keysym_desc __guac_rdp_keymap_mapping[] = {
/* space */ /* space */
@ -85,7 +79,7 @@ static guac_rdp_keysym_desc __guac_rdp_keymap_mapping[] = {
/* quoteright */ /* quoteright */
{ .keysym = 0x0027, .scancode = 0x05, { .keysym = 0x0027, .scancode = 0x05,
.clear_keysyms = GUAC_KEYSYMS_ALL_SHIFT }, .clear_keysyms = GUAC_KEYSYMS_ALL_SHIFT },
/* parenleft */ /* parenleft */
{ .keysym = 0x0028, .scancode = 0x06, { .keysym = 0x0028, .scancode = 0x06,
@ -477,7 +471,7 @@ static guac_rdp_keysym_desc __guac_rdp_keymap_mapping[] = {
/* ugrave */ /* ugrave */
{ .keysym = 0x00f9, .scancode = 0x28, { .keysym = 0x00f9, .scancode = 0x28,
.clear_keysyms = GUAC_KEYSYMS_ALL_SHIFT }, .clear_keysyms = GUAC_KEYSYMS_ALL_SHIFT },
/* euro */ /* euro */
{ .keysym = 0x10020ac, .scancode = 0x12, { .keysym = 0x10020ac, .scancode = 0x12,
@ -487,7 +481,7 @@ static guac_rdp_keysym_desc __guac_rdp_keymap_mapping[] = {
}; };
guac_rdp_keymap guac_rdp_keymap_fr_fr = { const guac_rdp_keymap guac_rdp_keymap_fr_fr = {
.name = "fr-fr-azerty", .name = "fr-fr-azerty",