Add French and German keymaps to build, add failsafe keymap, parse layout parameter, cleanup contributed keymaps, add missing declarations.
This commit is contained in:
parent
b6effd3d4f
commit
7ba047f5a8
@ -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 = \
|
||||
|
@ -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
|
||||
|
||||
|
@ -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);
|
||||
|
||||
|
@ -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 */
|
||||
|
@ -57,7 +57,7 @@ static guac_rdp_keysym_desc __guac_rdp_keymap_mapping[] = {
|
||||
/* quotedbl */
|
||||
{ .keysym = 0x0022, .scancode = 0x03,
|
||||
.set_keysyms = GUAC_KEYSYMS_SHIFT },
|
||||
|
||||
|
||||
/* numbersign */
|
||||
{ .keysym = 0x0023, .scancode = 0x2b,
|
||||
.clear_keysyms = GUAC_KEYSYMS_ALL_SHIFT },
|
||||
|
63
protocols/rdp/src/rdp_keymap_failsafe.c
Normal file
63
protocols/rdp/src/rdp_keymap_failsafe.c
Normal 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
|
||||
|
||||
};
|
||||
|
@ -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",
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user