1
0
mirror of https://git.tartarus.org/simon/putty.git synced 2025-01-10 18:07:59 +00:00

pterm: set IUTF8 on pty devices depending on charset.

In a UTF-8 pterm, it makes sense to set the IUTF8 flag (on systems
that have one) on the pty device, so that line editing will take
account of UTF-8 multibyte characters.

(cherry picked from commit 1840103c05)
This commit is contained in:
Simon Tatham 2015-09-01 18:35:38 +01:00
parent 14464764da
commit eb319f9b6e
3 changed files with 24 additions and 2 deletions

View File

@ -2914,6 +2914,12 @@ void uxsel_input_remove(int id) {
gdk_input_remove(id); gdk_input_remove(id);
} }
int frontend_is_utf8(void *frontend)
{
struct gui_data *inst = (struct gui_data *)frontend;
return inst->ucsdata.line_codepage == CS_UTF8;
}
char *setup_fonts_ucs(struct gui_data *inst) char *setup_fonts_ucs(struct gui_data *inst)
{ {
int shadowbold = conf_get_int(inst->conf, CONF_shadowbold); int shadowbold = conf_get_int(inst->conf, CONF_shadowbold);

View File

@ -77,6 +77,7 @@ unsigned long getticks(void); /* based on gettimeofday(2) */
char *get_x_display(void *frontend); char *get_x_display(void *frontend);
int font_dimension(void *frontend, int which);/* 0 for width, 1 for height */ int font_dimension(void *frontend, int which);/* 0 for width, 1 for height */
long get_windowid(void *frontend); long get_windowid(void *frontend);
int frontend_is_utf8(void *frontend);
/* Things gtkdlg.c needs from pterm.c */ /* Things gtkdlg.c needs from pterm.c */
void *get_window(void *frontend); /* void * to avoid depending on gtk.h */ void *get_window(void *frontend); /* void * to avoid depending on gtk.h */

View File

@ -738,14 +738,29 @@ static const char *pty_init(void *frontend, void **backend_handle, Conf *conf,
pty_open_master(pty); pty_open_master(pty);
/* /*
* Set the backspace character to be whichever of ^H and ^? is * Set up configuration-dependent termios settings on the new pty.
* specified by bksp_is_delete.
*/ */
{ {
struct termios attrs; struct termios attrs;
tcgetattr(pty->master_fd, &attrs); tcgetattr(pty->master_fd, &attrs);
/*
* Set the backspace character to be whichever of ^H and ^? is
* specified by bksp_is_delete.
*/
attrs.c_cc[VERASE] = conf_get_int(conf, CONF_bksp_is_delete) attrs.c_cc[VERASE] = conf_get_int(conf, CONF_bksp_is_delete)
? '\177' : '\010'; ? '\177' : '\010';
/*
* Set the IUTF8 bit iff the character set is UTF-8.
*/
#ifdef IUTF8
if (frontend_is_utf8(frontend))
attrs.c_iflag |= IUTF8;
else
attrs.c_iflag &= ~IUTF8;
#endif
tcsetattr(pty->master_fd, TCSANOW, &attrs); tcsetattr(pty->master_fd, TCSANOW, &attrs);
} }