/*
* CDDL HEADER START
*
* The contents of this file are subject to the terms of the
* Common Development and Distribution License, Version 1.0 only
* (the "License"). You may not use this file except in compliance
* with the License.
*
* You can obtain a copy of the license at usr/src/OPENSOLARIS.LICENSE
* or http://www.opensolaris.org/os/licensing.
* See the License for the specific language governing permissions
* and limitations under the License.
*
* When distributing Covered Code, include this CDDL HEADER in each
* file and include the License file at usr/src/OPENSOLARIS.LICENSE.
* If applicable, add the following below this CDDL HEADER, with the
* fields enclosed by brackets "[]" replaced with your own identifying
* information: Portions Copyright [yyyy] [name of copyright owner]
*
* CDDL HEADER END
*/
/*
* Copyright 1994 Sun Microsystems, Inc. All rights reserved.
* Use is subject to license terms.
*/
/* Copyright (c) 1983, 1984, 1985, 1986, 1987, 1988, 1989 AT&T */
/* All Rights Reserved */
/*
* University Copyright- Copyright (c) 1982, 1986, 1988
* The Regents of the University of California
* All Rights Reserved
*
* University Acknowledgment- Portions of this document are derived from
* software developed by the University of California, Berkeley, and its
* contributors.
*/
#pragma ident "%Z%%M% %I% %E% SMI"
/*
* init_disp contains the initialization code for the display package,
* as well as the signal handling routines
*/
#include "talk.h"
#include <signal.h>
#include <libintl.h>
#ifdef SYSV
#define signal(s, f) sigset(s, f)
#endif /* SYSV */
static void sig_sent();
/*
* set up curses, catch the appropriate signals, and build the
* various windows
*/
void
init_display()
{
initscr();
curses_initialized = 1;
clear();
refresh();
noecho();
crmode();
signal(SIGINT, sig_sent);
signal(SIGPIPE, sig_sent);
/* curses takes care of ^Z */
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);
/* let them know we are working on it */
current_state = gettext("No connection yet");
}
/*
* trade edit characters with the other talk. By agreement
* the first three characters each talk transmits after
* connection are the three edit characters
*/
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];
/* for SVID should be VERSE */
buf[1] = my_win.kill = tty.c_cc[VKILL];
buf[2] = my_win.werase = tty.c_cc[VWERASE];
/* for SVID should be VWERSE */
#else /* ! SYSV */
struct sgttyb tty;
struct ltchars ltc;
gtty(0, &tty);
ioctl(0, TIOCGLTC, (struct sgttyb *)&ltc);
my_win.cerase = tty.sg_erase;
my_win.kill = tty.sg_kill;
if (ltc.t_werasc == (char)-1) {
my_win.werase = '\027'; /* control W */
} else {
my_win.werase = ltc.t_werasc;
}
buf[0] = my_win.cerase;
buf[1] = my_win.kill;
buf[2] = my_win.werase;
#endif /* SYSV */
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();
}
/*
* All done talking...hang up the phone and reset terminal thingy's
*/
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);
}