#include "talk.h"
#include <signal.h>
#include <libintl.h>
#ifdef SYSV
#define signal(s, f) sigset(s, f)
#endif
static void sig_sent();
void
init_display()
{
initscr();
curses_initialized = 1;
clear();
refresh();
noecho();
crmode();
signal(SIGINT, sig_sent);
signal(SIGPIPE, sig_sent);
my_win.x_nlines = LINES / 2;
my_win.x_ncols = COLS;
my_win.x_win = newwin(my_win.x_nlines, my_win.x_ncols, 0, 0);
scrollok(my_win.x_win, FALSE);
wclear(my_win.x_win);
rem_win.x_nlines = LINES / 2 - 1;
rem_win.x_ncols = COLS;
rem_win.x_win = newwin(rem_win.x_nlines, rem_win.x_ncols,
my_win.x_nlines+1, 0);
scrollok(rem_win.x_win, FALSE);
wclear(rem_win.x_win);
line_win = newwin(1, COLS, my_win.x_nlines, 0);
box(line_win, '-', '-');
wrefresh(line_win);
current_state = gettext("No connection yet");
}
void
set_edit_chars()
{
char buf[3];
int cc;
#ifdef SYSV
struct termios tty;
ioctl(0, TCGETS, (struct termios *)&tty);
buf[0] = my_win.cerase = tty.c_cc[VERASE];
buf[1] = my_win.kill = tty.c_cc[VKILL];
buf[2] = my_win.werase = tty.c_cc[VWERASE];
#else
struct sgttyb tty;
struct ltchars ltc;
gtty(0, &tty);
ioctl(0, TIOCGLTC, (struct sgttyb *)<c);
my_win.cerase = tty.sg_erase;
my_win.kill = tty.sg_kill;
if (ltc.t_werasc == (char)-1) {
my_win.werase = '\027';
} else {
my_win.werase = ltc.t_werasc;
}
buf[0] = my_win.cerase;
buf[1] = my_win.kill;
buf[2] = my_win.werase;
#endif
cc = write(sockt, buf, sizeof (buf));
if (cc != sizeof (buf)) {
p_error(gettext("Lost the connection"));
}
cc = read(sockt, buf, sizeof (buf));
if (cc != sizeof (buf)) {
p_error(gettext("Lost the connection"));
}
rem_win.cerase = buf[0];
rem_win.kill = buf[1];
rem_win.werase = buf[2];
}
static void
sig_sent()
{
message(gettext("Connection closing. Exiting"));
quit();
}
void
quit()
{
if (curses_initialized) {
wmove(rem_win.x_win, rem_win.x_nlines-1, 0);
wclrtoeol(rem_win.x_win);
wrefresh(rem_win.x_win);
endwin();
}
if (invitation_waiting) {
send_delete();
}
exit(0);
}