Ticket #3697: (tty_init): unify curses initialization

...for various curses implementations.

Signed-off-by: Andrew Borodin <aborodin@vmail.ru>
This commit is contained in:
Thomas Dickey 2017-04-14 14:06:13 +03:00 committed by Andrew Borodin
parent 4f4df7d323
commit 4d46a10862

View File

@ -179,6 +179,8 @@ mc_tty_normalize_lines_char (const char *ch)
void
tty_init (gboolean mouse_enable, gboolean is_xterm)
{
struct termios mode;
initscr ();
#ifdef HAVE_ESCDELAY
@ -194,25 +196,15 @@ tty_init (gboolean mouse_enable, gboolean is_xterm)
ESCDELAY = 200;
#endif /* HAVE_ESCDELAY */
#ifdef NCURSES_VERSION
/* use Ctrl-g to generate SIGINT */
cur_term->Nttyb.c_cc[VINTR] = CTRL ('g'); /* ^g */
/* disable SIGQUIT to allow use Ctrl-\ key */
cur_term->Nttyb.c_cc[VQUIT] = NULL_VALUE;
tcsetattr (cur_term->Filedes, TCSANOW, &cur_term->Nttyb);
#else
/* other curses implementation (bsd curses, ...) */
{
struct termios mode;
tcgetattr (STDIN_FILENO, &mode);
/* use Ctrl-g to generate SIGINT */
mode.c_cc[VINTR] = CTRL ('g'); /* ^g */
/* disable SIGQUIT to allow use Ctrl-\ key */
mode.c_cc[VQUIT] = NULL_VALUE;
tcsetattr (STDIN_FILENO, TCSANOW, &mode);
}
#endif /* NCURSES_VERSION */
/* curses remembers the "in-program" modes after this call */
def_prog_mode ();
tty_start_interrupt_key ();