config root man

Current Path : /usr/src/contrib/nvi/tk/

FreeBSD hs32.drive.ne.jp 9.1-RELEASE FreeBSD 9.1-RELEASE #1: Wed Jan 14 12:18:08 JST 2015 root@hs32.drive.ne.jp:/sys/amd64/compile/hs32 amd64
Upload File :
Current File : //usr/src/contrib/nvi/tk/tk_term.c

/*-
 * Copyright (c) 1993, 1994
 *	The Regents of the University of California.  All rights reserved.
 * Copyright (c) 1993, 1994, 1995, 1996
 *	Keith Bostic.  All rights reserved.
 *
 * See the LICENSE file for redistribution information.
 */

#include "config.h"

#ifndef lint
static const char sccsid[] = "@(#)tk_term.c	8.12 (Berkeley) 10/13/96";
#endif /* not lint */

#include <sys/types.h>
#include <sys/queue.h>

#include <bitstring.h>
#include <errno.h>
#include <limits.h>
#include <signal.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <termios.h>
#include <unistd.h>

#include "../common/common.h"
#include "tki.h"

/*
 * tk_term_init --
 *	Initialize the terminal special keys.
 *
 * PUBLIC: int tk_term_init __P((SCR *));
 */
int
tk_term_init(sp)
	SCR *sp;
{
	SEQ *qp;

	/*
	 * Rework any function key mappings that were set before the
	 * screen was initialized.
	 */
	for (qp = sp->gp->seqq.lh_first; qp != NULL; qp = qp->q.le_next)
		if (F_ISSET(qp, SEQ_FUNCMAP))
			(void)tk_fmap(sp, qp->stype,
			    qp->input, qp->ilen, qp->output, qp->olen);
	return (0);
}

/*
 * tk_term_end --
 *	End the special keys defined by the termcap/terminfo entry.
 *
 * PUBLIC: int tk_term_end __P((GS *));
 */
int
tk_term_end(gp)
	GS *gp;
{
	SEQ *qp, *nqp;

	/* Delete screen specific mappings. */
	for (qp = gp->seqq.lh_first; qp != NULL; qp = nqp) {
		nqp = qp->q.le_next;
		if (F_ISSET(qp, SEQ_SCREEN))
			(void)seq_mdel(qp);
	}
	return (0);
}

/*
 * tk_fmap --
 *	Map a function key.
 *
 * PUBLIC: int tk_fmap __P((SCR *, seq_t, CHAR_T *, size_t, CHAR_T *, size_t));
 */
int
tk_fmap(sp, stype, from, flen, to, tlen)
	SCR *sp;
	seq_t stype;
	CHAR_T *from, *to;
	size_t flen, tlen;
{
	VI_INIT_IGNORE(sp);

	/* Bind a Tk/Tcl function key to a string sequence. */
	return (0);
}

/*
 * tk_optchange --
 *	Curses screen specific "option changed" routine.
 *
 * PUBLIC: int tk_optchange __P((SCR *, int, char *, u_long *));
 */
int
tk_optchange(sp, opt, str, valp)
	SCR *sp;
	int opt;
	char *str;
	u_long *valp;
{
	switch (opt) {
	case O_COLUMNS:
	case O_LINES:
		/*
		 * Changing the columns or lines require that we restart
		 * the screen.
		 */
		F_SET(sp->gp, G_SRESTART);
		F_CLR(sp, SC_SCR_EX | SC_SCR_VI);
		break;
	case O_TERM:
		msgq(sp, M_ERR, "The screen type may not be changed");
		return (1);
	}
	return (0);
}

/*
 * tk_ssize --
 *	Return the window size.
 *
 * PUBLIC: int tk_ssize __P((SCR *, int, size_t *, size_t *, int *));
 */
int
tk_ssize(sp, sigwinch, rowp, colp, changedp)
	SCR *sp;
	int sigwinch;
	size_t *rowp, *colp;
	int *changedp;
{
	TK_PRIVATE *tkp;

	tkp = GTKP(__global_list);
	(void)Tcl_Eval(tkp->interp, "tk_ssize");

	/*
	 * SunOS systems deliver SIGWINCH when windows are uncovered
	 * as well as when they change size.  In addition, we call
	 * here when continuing after being suspended since the window
	 * may have changed size.  Since we don't want to background
	 * all of the screens just because the window was uncovered,
	 * ignore the signal if there's no change.
	 *
	 * !!!
	 * sp may be NULL.
	 */
	if (sigwinch && sp != NULL &&
	    tkp->tk_ssize_row == O_VAL(sp, O_LINES) &&
	    tkp->tk_ssize_col == O_VAL(sp, O_COLUMNS)) {
		if (changedp != NULL)
			*changedp = 0;
		return (0);
	}

	if (rowp != NULL)
		*rowp = tkp->tk_ssize_row;
	if (colp != NULL)
		*colp = tkp->tk_ssize_col;
	if (changedp != NULL)
		*changedp = 1;
	return (0);
}

Man Man