mirror of
https://git.tartarus.org/simon/putty.git
synced 2025-01-26 01:32:25 +00:00
Support for non-ISO-8859-1 X keysyms. So in particular, pterm in a
Euro-supporting font with a Euro-enabled X key map will now actually generate a Euro character rather than shrugging and doing nothing. [originally from svn r3151]
This commit is contained in:
parent
95159b8283
commit
082cf832c5
20
Recipe
20
Recipe
@ -97,8 +97,9 @@
|
|||||||
GUITERM = window windlg winctrls terminal sizetip wcwidth unicode ldiscucs
|
GUITERM = window windlg winctrls terminal sizetip wcwidth unicode ldiscucs
|
||||||
+ logging printing winutils dialog config wincfg tree234
|
+ logging printing winutils dialog config wincfg tree234
|
||||||
|
|
||||||
# Config box on Unix.
|
# Same thing on Unix.
|
||||||
UXCFG = config uxcfg dialog gtkdlg gtkcols gtkpanel
|
UXTERM = pterm config uxcfg dialog gtkdlg gtkcols gtkpanel tree234
|
||||||
|
+ terminal wcwidth uxucs ldiscucs logging uxprint xkeysym
|
||||||
|
|
||||||
# Non-SSH back ends (putty, puttytel, plink).
|
# Non-SSH back ends (putty, puttytel, plink).
|
||||||
NONSSH = telnet raw rlogin ldisc
|
NONSSH = telnet raw rlogin ldisc
|
||||||
@ -152,15 +153,12 @@ puttygen : [G] puttygen sshrsag sshdssg sshprime sshdes sshbn sshmd5 version
|
|||||||
+ sshrand noise sshsha winstore misc winctrls sshrsa sshdss winmisc
|
+ sshrand noise sshsha winstore misc winctrls sshrsa sshdss winmisc
|
||||||
+ sshpubk sshaes sshsh512 import winutils puttygen.res tree234 LIBS
|
+ sshpubk sshaes sshsh512 import winutils puttygen.res tree234 LIBS
|
||||||
|
|
||||||
pterm : [X] pterm terminal wcwidth uxucs uxmisc tree234 misc ldisc ldiscucs
|
pterm : [X] UXTERM uxmisc misc ldisc settings pty uxsel be_none uxstore
|
||||||
+ logging uxprint settings pty uxsel be_none uxstore signal CHARSET
|
+ signal CHARSET cmdline ptermm version
|
||||||
+ cmdline ptermm UXCFG version
|
putty : [X] UXTERM uxmisc misc ldisc settings pty uxsel be_all uxstore
|
||||||
putty : [X] pterm terminal wcwidth uxucs uxmisc tree234 misc ldisc ldiscucs
|
+ signal CHARSET uxputty NONSSH UXSSH UXMISC ux_x11
|
||||||
+ logging uxprint settings pty uxsel be_all uxstore signal CHARSET
|
puttytel : [X] UXTERM uxmisc misc ldisc settings pty uxsel be_nossh uxstore
|
||||||
+ uxputty NONSSH UXSSH UXMISC logging ux_x11 UXCFG
|
+ signal CHARSET uxputty NONSSH UXMISC
|
||||||
puttytel : [X] pterm terminal wcwidth uxucs uxmisc tree234 misc ldisc ldiscucs
|
|
||||||
+ logging uxprint settings pty uxsel be_nossh uxstore signal CHARSET
|
|
||||||
+ uxputty NONSSH UXMISC logging UXCFG
|
|
||||||
|
|
||||||
plink : [U] uxplink uxcons NONSSH UXSSH be_all logging UXMISC signal ux_x11
|
plink : [U] uxplink uxcons NONSSH UXSSH be_all logging UXMISC signal ux_x11
|
||||||
|
|
||||||
|
72
unix/pterm.c
72
unix/pterm.c
@ -440,11 +440,12 @@ gint key_event(GtkWidget *widget, GdkEventKey *event, gpointer data)
|
|||||||
{
|
{
|
||||||
struct gui_data *inst = (struct gui_data *)data;
|
struct gui_data *inst = (struct gui_data *)data;
|
||||||
char output[32];
|
char output[32];
|
||||||
int start, end, special;
|
wchar_t ucsoutput[2];
|
||||||
|
int ucsval, start, end, special, use_ucsoutput;
|
||||||
|
|
||||||
/* By default, nothing is generated. */
|
/* By default, nothing is generated. */
|
||||||
end = start = 0;
|
end = start = 0;
|
||||||
special = FALSE;
|
special = use_ucsoutput = FALSE;
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* If Alt is being released after typing an Alt+numberpad
|
* If Alt is being released after typing an Alt+numberpad
|
||||||
@ -566,12 +567,21 @@ gint key_event(GtkWidget *widget, GdkEventKey *event, gpointer data)
|
|||||||
}
|
}
|
||||||
|
|
||||||
special = FALSE;
|
special = FALSE;
|
||||||
|
use_ucsoutput = FALSE;
|
||||||
|
|
||||||
/* ALT+things gives leading Escape. */
|
/* ALT+things gives leading Escape. */
|
||||||
output[0] = '\033';
|
output[0] = '\033';
|
||||||
strncpy(output+1, event->string, 31);
|
strncpy(output+1, event->string, 31);
|
||||||
output[31] = '\0';
|
if (!*event->string &&
|
||||||
end = strlen(output);
|
(ucsval = keysym_to_unicode(event->keyval)) >= 0) {
|
||||||
|
ucsoutput[0] = '\033';
|
||||||
|
ucsoutput[1] = ucsval;
|
||||||
|
use_ucsoutput = TRUE;
|
||||||
|
end = 2;
|
||||||
|
} else {
|
||||||
|
output[31] = '\0';
|
||||||
|
end = strlen(output);
|
||||||
|
}
|
||||||
if (event->state & GDK_MOD1_MASK) {
|
if (event->state & GDK_MOD1_MASK) {
|
||||||
start = 0;
|
start = 0;
|
||||||
if (end == 1) end = 0;
|
if (end == 1) end = 0;
|
||||||
@ -582,6 +592,7 @@ gint key_event(GtkWidget *widget, GdkEventKey *event, gpointer data)
|
|||||||
if (!event->string[0] && event->keyval == '`' &&
|
if (!event->string[0] && event->keyval == '`' &&
|
||||||
(event->state & GDK_CONTROL_MASK)) {
|
(event->state & GDK_CONTROL_MASK)) {
|
||||||
output[1] = '\x1C';
|
output[1] = '\x1C';
|
||||||
|
use_ucsoutput = FALSE;
|
||||||
end = 2;
|
end = 2;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -589,6 +600,7 @@ gint key_event(GtkWidget *widget, GdkEventKey *event, gpointer data)
|
|||||||
if (event->keyval == GDK_Break &&
|
if (event->keyval == GDK_Break &&
|
||||||
(event->state & GDK_CONTROL_MASK)) {
|
(event->state & GDK_CONTROL_MASK)) {
|
||||||
output[1] = '\003';
|
output[1] = '\003';
|
||||||
|
use_ucsoutput = FALSE;
|
||||||
end = 2;
|
end = 2;
|
||||||
special = TRUE;
|
special = TRUE;
|
||||||
}
|
}
|
||||||
@ -597,6 +609,7 @@ gint key_event(GtkWidget *widget, GdkEventKey *event, gpointer data)
|
|||||||
* special to ldisc. */
|
* special to ldisc. */
|
||||||
if (event->keyval == GDK_Return) {
|
if (event->keyval == GDK_Return) {
|
||||||
output[1] = '\015';
|
output[1] = '\015';
|
||||||
|
use_ucsoutput = FALSE;
|
||||||
end = 2;
|
end = 2;
|
||||||
special = TRUE;
|
special = TRUE;
|
||||||
}
|
}
|
||||||
@ -608,6 +621,7 @@ gint key_event(GtkWidget *widget, GdkEventKey *event, gpointer data)
|
|||||||
(event->state & (GDK_SHIFT_MASK |
|
(event->state & (GDK_SHIFT_MASK |
|
||||||
GDK_CONTROL_MASK)) == GDK_CONTROL_MASK) {
|
GDK_CONTROL_MASK)) == GDK_CONTROL_MASK) {
|
||||||
output[1] = '\0';
|
output[1] = '\0';
|
||||||
|
use_ucsoutput = FALSE;
|
||||||
end = 2;
|
end = 2;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -616,6 +630,7 @@ gint key_event(GtkWidget *widget, GdkEventKey *event, gpointer data)
|
|||||||
(event->state & (GDK_SHIFT_MASK | GDK_CONTROL_MASK)) ==
|
(event->state & (GDK_SHIFT_MASK | GDK_CONTROL_MASK)) ==
|
||||||
(GDK_SHIFT_MASK | GDK_CONTROL_MASK)) {
|
(GDK_SHIFT_MASK | GDK_CONTROL_MASK)) {
|
||||||
output[1] = '\240';
|
output[1] = '\240';
|
||||||
|
use_ucsoutput = FALSE;
|
||||||
end = 2;
|
end = 2;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -623,6 +638,7 @@ gint key_event(GtkWidget *widget, GdkEventKey *event, gpointer data)
|
|||||||
if (event->keyval == GDK_BackSpace &&
|
if (event->keyval == GDK_BackSpace &&
|
||||||
!(event->state & GDK_SHIFT_MASK)) {
|
!(event->state & GDK_SHIFT_MASK)) {
|
||||||
output[1] = inst->cfg.bksp_is_delete ? '\x7F' : '\x08';
|
output[1] = inst->cfg.bksp_is_delete ? '\x7F' : '\x08';
|
||||||
|
use_ucsoutput = FALSE;
|
||||||
end = 2;
|
end = 2;
|
||||||
special = TRUE;
|
special = TRUE;
|
||||||
}
|
}
|
||||||
@ -630,6 +646,7 @@ gint key_event(GtkWidget *widget, GdkEventKey *event, gpointer data)
|
|||||||
if (event->keyval == GDK_BackSpace &&
|
if (event->keyval == GDK_BackSpace &&
|
||||||
(event->state & GDK_SHIFT_MASK)) {
|
(event->state & GDK_SHIFT_MASK)) {
|
||||||
output[1] = inst->cfg.bksp_is_delete ? '\x08' : '\x7F';
|
output[1] = inst->cfg.bksp_is_delete ? '\x08' : '\x7F';
|
||||||
|
use_ucsoutput = FALSE;
|
||||||
end = 2;
|
end = 2;
|
||||||
special = TRUE;
|
special = TRUE;
|
||||||
}
|
}
|
||||||
@ -638,6 +655,7 @@ gint key_event(GtkWidget *widget, GdkEventKey *event, gpointer data)
|
|||||||
if (event->keyval == GDK_ISO_Left_Tab ||
|
if (event->keyval == GDK_ISO_Left_Tab ||
|
||||||
(event->keyval == GDK_Tab && (event->state & GDK_SHIFT_MASK))) {
|
(event->keyval == GDK_Tab && (event->state & GDK_SHIFT_MASK))) {
|
||||||
end = 1 + sprintf(output+1, "\033[Z");
|
end = 1 + sprintf(output+1, "\033[Z");
|
||||||
|
use_ucsoutput = FALSE;
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
@ -662,6 +680,7 @@ gint key_event(GtkWidget *widget, GdkEventKey *event, gpointer data)
|
|||||||
output[1] = keys[1];
|
output[1] = keys[1];
|
||||||
else
|
else
|
||||||
output[1] = keys[0];
|
output[1] = keys[0];
|
||||||
|
use_ucsoutput = FALSE;
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -714,6 +733,7 @@ gint key_event(GtkWidget *widget, GdkEventKey *event, gpointer data)
|
|||||||
end = 1 + sprintf(output+1, "\033?%c", xkey);
|
end = 1 + sprintf(output+1, "\033?%c", xkey);
|
||||||
} else
|
} else
|
||||||
end = 1 + sprintf(output+1, "\033O%c", xkey);
|
end = 1 + sprintf(output+1, "\033O%c", xkey);
|
||||||
|
use_ucsoutput = FALSE;
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -817,6 +837,7 @@ gint key_event(GtkWidget *widget, GdkEventKey *event, gpointer data)
|
|||||||
|
|
||||||
if (inst->term->vt52_mode && code > 0 && code <= 6) {
|
if (inst->term->vt52_mode && code > 0 && code <= 6) {
|
||||||
end = 1 + sprintf(output+1, "\x1B%c", " HLMEIG"[code]);
|
end = 1 + sprintf(output+1, "\x1B%c", " HLMEIG"[code]);
|
||||||
|
use_ucsoutput = FALSE;
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -841,6 +862,7 @@ gint key_event(GtkWidget *widget, GdkEventKey *event, gpointer data)
|
|||||||
if (event->state & GDK_SHIFT_MASK) index += 12;
|
if (event->state & GDK_SHIFT_MASK) index += 12;
|
||||||
if (event->state & GDK_CONTROL_MASK) index += 24;
|
if (event->state & GDK_CONTROL_MASK) index += 24;
|
||||||
end = 1 + sprintf(output+1, "\x1B[%c", codes[index]);
|
end = 1 + sprintf(output+1, "\x1B[%c", codes[index]);
|
||||||
|
use_ucsoutput = FALSE;
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
if (inst->cfg.funky_type == 5 && /* SCO small keypad */
|
if (inst->cfg.funky_type == 5 && /* SCO small keypad */
|
||||||
@ -852,6 +874,7 @@ gint key_event(GtkWidget *widget, GdkEventKey *event, gpointer data)
|
|||||||
} else {
|
} else {
|
||||||
end = 1 + sprintf(output+1, "\x1B[%c", codes[code-1]);
|
end = 1 + sprintf(output+1, "\x1B[%c", codes[code-1]);
|
||||||
}
|
}
|
||||||
|
use_ucsoutput = FALSE;
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
if ((inst->term->vt52_mode || inst->cfg.funky_type == 4) &&
|
if ((inst->term->vt52_mode || inst->cfg.funky_type == 4) &&
|
||||||
@ -867,10 +890,12 @@ gint key_event(GtkWidget *widget, GdkEventKey *event, gpointer data)
|
|||||||
else
|
else
|
||||||
end = 1 + sprintf(output+1,
|
end = 1 + sprintf(output+1,
|
||||||
"\x1BO%c", code + 'P' - 11 - offt);
|
"\x1BO%c", code + 'P' - 11 - offt);
|
||||||
|
use_ucsoutput = FALSE;
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
if (inst->cfg.funky_type == 1 && code >= 11 && code <= 15) {
|
if (inst->cfg.funky_type == 1 && code >= 11 && code <= 15) {
|
||||||
end = 1 + sprintf(output+1, "\x1B[[%c", code + 'A' - 11);
|
end = 1 + sprintf(output+1, "\x1B[[%c", code + 'A' - 11);
|
||||||
|
use_ucsoutput = FALSE;
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
if (inst->cfg.funky_type == 2 && code >= 11 && code <= 14) {
|
if (inst->cfg.funky_type == 2 && code >= 11 && code <= 14) {
|
||||||
@ -878,14 +903,17 @@ gint key_event(GtkWidget *widget, GdkEventKey *event, gpointer data)
|
|||||||
end = 1 + sprintf(output+1, "\x1B%c", code + 'P' - 11);
|
end = 1 + sprintf(output+1, "\x1B%c", code + 'P' - 11);
|
||||||
else
|
else
|
||||||
end = 1 + sprintf(output+1, "\x1BO%c", code + 'P' - 11);
|
end = 1 + sprintf(output+1, "\x1BO%c", code + 'P' - 11);
|
||||||
|
use_ucsoutput = FALSE;
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
if (inst->cfg.rxvt_homeend && (code == 1 || code == 4)) {
|
if (inst->cfg.rxvt_homeend && (code == 1 || code == 4)) {
|
||||||
end = 1 + sprintf(output+1, code == 1 ? "\x1B[H" : "\x1BOw");
|
end = 1 + sprintf(output+1, code == 1 ? "\x1B[H" : "\x1BOw");
|
||||||
|
use_ucsoutput = FALSE;
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
if (code) {
|
if (code) {
|
||||||
end = 1 + sprintf(output+1, "\x1B[%d~", code);
|
end = 1 + sprintf(output+1, "\x1B[%d~", code);
|
||||||
|
use_ucsoutput = FALSE;
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -920,6 +948,7 @@ gint key_event(GtkWidget *widget, GdkEventKey *event, gpointer data)
|
|||||||
} else {
|
} else {
|
||||||
end = 1 + sprintf(output+1, "\033[%c", xkey);
|
end = 1 + sprintf(output+1, "\033[%c", xkey);
|
||||||
}
|
}
|
||||||
|
use_ucsoutput = FALSE;
|
||||||
goto done;
|
goto done;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
@ -945,19 +974,28 @@ gint key_event(GtkWidget *widget, GdkEventKey *event, gpointer data)
|
|||||||
output[end] = '\0'; /* NUL-terminate */
|
output[end] = '\0'; /* NUL-terminate */
|
||||||
ldisc_send(inst->ldisc, output+start, -2, 1);
|
ldisc_send(inst->ldisc, output+start, -2, 1);
|
||||||
} else if (!inst->direct_to_font) {
|
} else if (!inst->direct_to_font) {
|
||||||
/*
|
if (!use_ucsoutput) {
|
||||||
* The stuff we've just generated is assumed to be
|
/*
|
||||||
* ISO-8859-1! This sounds insane, but `man
|
* The stuff we've just generated is assumed to be
|
||||||
* XLookupString' agrees: strings of this type returned
|
* ISO-8859-1! This sounds insane, but `man
|
||||||
* from the X server are hardcoded to 8859-1. Strictly
|
* XLookupString' agrees: strings of this type
|
||||||
* speaking we should be doing this using some sort of
|
* returned from the X server are hardcoded to
|
||||||
* GtkIMContext, which (if we're lucky) would give us
|
* 8859-1. Strictly speaking we should be doing
|
||||||
* our data directly in Unicode; but that's not
|
* this using some sort of GtkIMContext, which (if
|
||||||
* supported in GTK 1.2 as far as I can tell, and it's
|
* we're lucky) would give us our data directly in
|
||||||
* poorly documented even in 2.0, so it'll have to
|
* Unicode; but that's not supported in GTK 1.2 as
|
||||||
* wait.
|
* far as I can tell, and it's poorly documented
|
||||||
*/
|
* even in 2.0, so it'll have to wait.
|
||||||
lpage_send(inst->ldisc, CS_ISO8859_1, output+start, end-start, 1);
|
*/
|
||||||
|
lpage_send(inst->ldisc, CS_ISO8859_1, output+start,
|
||||||
|
end-start, 1);
|
||||||
|
} else {
|
||||||
|
/*
|
||||||
|
* We generated our own Unicode key data from the
|
||||||
|
* keysym, so use that instead.
|
||||||
|
*/
|
||||||
|
luni_send(inst->ldisc, ucsoutput+start, end-start, 1);
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
/*
|
/*
|
||||||
* In direct-to-font mode, we just send the string
|
* In direct-to-font mode, we just send the string
|
||||||
|
@ -71,6 +71,9 @@ int reallyclose(void *frontend);
|
|||||||
char *make_default_wintitle(char *hostname);
|
char *make_default_wintitle(char *hostname);
|
||||||
int process_nonoption_arg(char *arg, Config *cfg);
|
int process_nonoption_arg(char *arg, Config *cfg);
|
||||||
|
|
||||||
|
/* pterm.c needs this special function in xkeysym.c */
|
||||||
|
int keysym_to_unicode(int keysym);
|
||||||
|
|
||||||
/* Things uxstore.c needs from pterm.c */
|
/* Things uxstore.c needs from pterm.c */
|
||||||
char *x_get_default(const char *key);
|
char *x_get_default(const char *key);
|
||||||
|
|
||||||
|
1011
unix/xkeysym.c
Normal file
1011
unix/xkeysym.c
Normal file
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue
Block a user