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
libguac_client_rdp_la_SOURCES = \
$(OGG_SOURCES) \
src/audio.c \
src/client.c \
src/default_pointer.c \
src/guac_handlers.c \
src/rdp_bitmap.c \
src/rdp_cliprdr.c \
src/rdp_gdi.c \
src/rdp_glyph.c \
src/rdp_keymap_base.c \
src/rdp_keymap.c \
src/rdp_keymap_de_de.c \
src/rdp_keymap_en_us.c \
src/rdp_pointer.c \
$(OGG_SOURCES) \
src/audio.c \
src/client.c \
src/default_pointer.c \
src/guac_handlers.c \
src/rdp_bitmap.c \
src/rdp_cliprdr.c \
src/rdp_gdi.c \
src/rdp_glyph.c \
src/rdp_keymap_base.c \
src/rdp_keymap.c \
src/rdp_keymap_de_de.c \
src/rdp_keymap_failsafe.c \
src/rdp_keymap_fr_fr.c \
src/rdp_keymap_en_us.c \
src/rdp_pointer.c \
src/wav_encoder.c
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];
/**
* Map of X11 keysyms to RDP scancodes (US English).
* US English keymap.
*/
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;
/**
* 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;
@ -172,6 +182,16 @@ extern const int GUAC_KEYSYMS_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.
*/
@ -180,7 +200,7 @@ extern const int GUAC_KEYSYMS_ALL_MODIFIERS[];
/**
* NULL-terminated array of all keymaps.
*/
extern const guac_rpd_keymap* GUAC_KEYMAPS[];
extern const guac_rdp_keymap* GUAC_KEYMAPS[];
#endif

View File

@ -527,16 +527,37 @@ int guac_client_init(guac_client* client, int argc, char** argv) {
/* US English Qwerty */
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 */
if (strcmp("en-us-qwerty", argv[IDX_LAYOUT]) == 0)
chosen_keymap = &rdp_guac_keymap_en_us;
/* German Qwertz */
else if (strcmp("de-de-qwertz", argv[IDX_LAYOUT]) == 0)
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 */
__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_ALL_ALT[] = {0xFFE9, 0xFFEA, 0};
const int GUAC_KEYSYMS_CTRL_ALT[] = {0xFFE3, 0xFFE9, 0};
const int GUAC_KEYSYMS_ALL_MODIFIERS[] = {
0xFFE1, 0xFFE2, /* Left and right shift */
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"
/*
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[] = {
/* space */
@ -85,7 +79,7 @@ static guac_rdp_keysym_desc __guac_rdp_keymap_mapping[] = {
/* quoteright */
{ .keysym = 0x0027, .scancode = 0x05,
.clear_keysyms = GUAC_KEYSYMS_ALL_SHIFT },
.clear_keysyms = GUAC_KEYSYMS_ALL_SHIFT },
/* parenleft */
{ .keysym = 0x0028, .scancode = 0x06,
@ -477,7 +471,7 @@ static guac_rdp_keysym_desc __guac_rdp_keymap_mapping[] = {
/* ugrave */
{ .keysym = 0x00f9, .scancode = 0x28,
.clear_keysyms = GUAC_KEYSYMS_ALL_SHIFT },
.clear_keysyms = GUAC_KEYSYMS_ALL_SHIFT },
/* euro */
{ .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",