|
|
researchv9-SUN3(old)
/*
* $Source: /var/lib/cvsd/repos/research/researchv9/X11/src/X.V11R1/clients/xterm/ptyx.h,v $
* $Header: /var/lib/cvsd/repos/research/researchv9/X11/src/X.V11R1/clients/xterm/ptyx.h,v 1.1.1.1 2018/04/24 17:22:00 root Exp $
*/
#include <X11/copyright.h>
/*
* Copyright 1987 by Digital Equipment Corporation, Maynard, Massachusetts.
*
* All Rights Reserved
*
* Permission to use, copy, modify, and distribute this software and its
* documentation for any purpose and without fee is hereby granted,
* provided that the above copyright notice appear in all copies and that
* both that copyright notice and this permission notice appear in
* supporting documentation, and that the name of Digital Equipment
* Corporation not be used in advertising or publicity pertaining to
* distribution of the software without specific, written prior permission.
*
*
* DIGITAL DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE, INCLUDING
* ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS, IN NO EVENT SHALL
* DIGITAL BE LIABLE FOR ANY SPECIAL, INDIRECT OR CONSEQUENTIAL DAMAGES OR
* ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS,
* WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION,
* ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS
* SOFTWARE.
*/
/* ptyx.h */
/* @(#)ptyx.h X10/6.6 11/10/86 */
#include <X11/Xlib.h>
/* Extra Xlib definitions */
#define AllButtonsUp(detail, ignore) (\
((ignore) == Button1) ? \
(((detail)&(Button2Mask|Button3Mask)) == 0) \
: \
(((ignore) == Button2) ? \
(((detail)&(Button1Mask|Button3Mask)) == 0) \
: \
(((detail)&(Button1Mask|Button2Mask)) == 0)) \
)
#define Max(i, j) ((i) > (j) ? (i) : (j))
#define MAX_COLS 200
#define MAX_ROWS 128
/* Until the translation manager comes along, I have to do my own translation of
* mouse events into the proper routines. */
typedef enum {NORMAL, LEFTEXTENSION, RIGHTEXTENSION} EventMode;
/*
* The origin of a screen is 0, 0. Therefore, the number of rows
* on a screen is screen->max_row + 1, and similarly for columns.
*/
typedef char **ScrnBuf;
/*
* ANSI emulation.
*/
#define INQ 0x05
#define FF 0x0C /* C0, C1 control names */
#define LS1 0x0E
#define LS0 0x0F
#define CAN 0x18
#define SUB 0x1A
#define ESC 0x1B
#define US 0x1F
#define DEL 0x7F
#define HTS ('H'+0x40')
#define SS2 0x8E
#define SS3 0x8F
#define DCS 0x90
#define OLDID 0x9A /* ESC Z */
#define CSI 0x9B
#define ST 0x9C
#define OSC 0x9D
#define PM 0x9E
#define APC 0x9F
#define RDEL 0xFF
#define NBOX 5 /* Number of Points in box */
#define NPARAM 10 /* Max. parameters */
#define MINHILITE 32
typedef struct {
unsigned char a_type;
unsigned char a_pintro;
unsigned char a_final;
unsigned char a_inters;
char a_nparam; /* # of parameters */
char a_dflt[NPARAM]; /* Default value flags */
short a_param[NPARAM]; /* Parameters */
char a_nastyf; /* Error flag */
} ANSI;
typedef struct {
int row;
int col;
unsigned flags; /* Vt100 saves graphics rendition. Ugh! */
char curgl;
char curgr;
char gsets[4];
} SavedCursor;
#define TEKNUMFONTS 4
/* Actually there are 5 types of lines, but four are non-solid lines */
#define TEKNUMLINES 4
typedef struct {
int x;
int y;
int fontsize;
int linetype;
} Tmodes;
typedef struct {
int Twidth;
int Theight;
} T_fontsize;
typedef struct {
short *bits;
int x;
int y;
int width;
int height;
} BitmapBits;
#define SAVELINES 64 /* default # lines to save */
#define SCROLLBARWIDTH 15 /* scroll bar width */
typedef struct {
/* These parameters apply to both windows */
Display *display; /* X display for screen */
int respond; /* socket for responses
(position report, etc.) */
long pid; /* pid of process on far side */
int uid; /* user id of actual person */
int gid; /* group id of actual person */
int color; /* colors used */
GC normalGC; /* normal painting */
GC reverseGC; /* reverse painting */
GC normalboldGC; /* normal painting, bold font */
GC reverseboldGC; /* reverse painting, bold font */
GC cursorGC; /* normal cursor painting */
GC reversecursorGC;/* reverse cursor painting */
unsigned long foreground; /* foreground color */
unsigned long background; /* Background color */
unsigned long cursorcolor; /* Cursor color */
unsigned long mousecolor; /* Mouse color */
int border; /* inner border */
int borderwidth; /* outer border */
unsigned long bordercolor; /* border Pixel color */
Pixmap graybordertile; /* tile pixmap for border when
window is unselected */
Cursor arrow; /* arrow cursor */
unsigned short send_mouse_pos; /* user wants mouse transition */
/* and position information */
int select; /* xterm selected */
int visualbell; /* visual bell mode */
int logging; /* logging mode */
int logfd; /* file descriptor of log */
char *logfile; /* log file name */
char *logstart; /* current start of log buffer */
int inhibit; /* flags for inhibiting changes */
/* VT window parameters */
struct {
Window window; /* X window id */
int width; /* width of columns */
int height; /* height of rows */
int fullwidth; /* full width of window */
int fullheight; /* full height of window */
int f_width; /* width of fonts in pixels */
int f_height; /* height of fonts in pixels */
} fullVwin;
Cursor curs; /* cursor resource from X */
/* Terminal fonts must be of the same size and of fixed width */
XFontStruct *fnt_norm; /* normal font of terminal */
XFontStruct *fnt_bold; /* bold font of terminal */
int enbolden; /* overstrike for bold font */
XPoint *box; /* draw unselected cursor */
int cursor_state; /* ON or OFF */
int cursor_set; /* requested state */
int cursor_col; /* previous cursor column */
int cursor_row; /* previous cursor row */
int cur_col; /* current cursor column */
int cur_row; /* current cursor row */
int max_col; /* rightmost column */
int max_row; /* bottom row */
int top_marg; /* top line of scrolling region */
int bot_marg; /* bottom line of " " */
Window scrollWindow; /* pointer to scrollbar struct */
int scrollbar; /* if > 0, width of scrollbar, and
scrollbar is showing */
int topline; /* line number of top, <= 0 */
int savedlines; /* number of lines that've been saved */
int savelines; /* number of lines off top to save */
int scrollinput; /* scroll to bottom on input */
int scrollkey; /* scroll to bottom on key */
ScrnBuf buf; /* screen buffer (main) */
ScrnBuf allbuf; /* screen buffer (may include
lines scrolled off top */
ScrnBuf altbuf; /* alternate screen buffer */
int alternate; /* true if using alternate buf */
unsigned short do_wrap; /* true if cursor in last column
and character just output */
int incopy; /* 0 if no RasterCopy exposure
event processed since last
RasterCopy */
int c132; /* allow change to 132 columns */
int curses; /* cludge-ups for more and vi */
int marginbell; /* true if margin bell on */
int nmarginbell; /* columns from right margin */
int bellarmed; /* cursor below bell margin */
unsigned int multiscroll; /* true if multi-scroll */
int scrolls; /* outstanding scroll count */
SavedCursor sc; /* data for restore cursor */
char *iconname; /* name in icon */
int iconnamelen; /* length of icon name */
char *titlename; /* name in title */
int titlenamelen; /* length of title name */
int save_modes[19]; /* save dec private modes */
/* Improved VT100 emulation stuff. */
char gsets[4]; /* G0 through G3. */
char curgl; /* Current GL setting. */
char curgr; /* Current GR setting. */
char curss; /* Current single shift. */
int scroll_amt; /* amount to scroll */
int refresh_amt; /* amount to refresh */
int jumpscroll; /* whether we should jumpscroll */
/* Tektronix window parameters */
GC TnormalGC; /* normal painting */
GC TcursorGC; /* normal cursor painting */
unsigned long Tforeground; /* foreground color */
unsigned long Tbackground; /* Background color */
unsigned long Tcursorcolor; /* Cursor color */
Pixmap Tbgndtile; /* background tile pixmap */
int Tcolor; /* colors used */
int planeused; /* is xorplane being used */
int cellsused; /* are color cells being used */
XColor colorcells[3]; /* color cells for Tek */
int Tshow; /* Tek window showing */
int waitrefresh; /* postpone refresh */
struct {
Window window; /* X window id */
int width; /* width of columns */
int height; /* height of rows */
int fullwidth; /* full width of window */
int fullheight; /* full height of window */
double tekscale; /* scale factor Tek -> vs100 */
} fullTwin;
XPoint **Tbox; /* draw unselected cursor */
int xorplane; /* z plane for inverts */
GC linepat[TEKNUMLINES]; /* line patterns */
XFontStruct *Tfont[TEKNUMFONTS]; /* Tek fonts */
int tobaseline[TEKNUMFONTS]; /* top to baseline for
each font */
int TekEmu; /* true if Tektronix emulation */
int cur_X; /* current x */
int cur_Y; /* current y */
Tmodes cur; /* current tek modes */
Tmodes page; /* starting tek modes on page */
int margin; /* 0 -> margin 1, 1 -> margin 2 */
int pen; /* current Tektronix pen 0=up, 1=dn */
char *TekGIN; /* nonzero if Tektronix GIN mode*/
char *Ticonname; /* name in icon */
int Ticonnamelen; /* length of icon name */
char *Ttitlename; /* name of title */
int Ttitlenamelen; /* length of title name */
} TScreen;
/* meaning of bits in screen.select flag */
#define INWINDOW 01 /* the mouse is in one of the windows */
#define FOCUS 02 /* one of the windows is the focus window */
typedef struct
{
unsigned flags;
} TKeyboard;
/* define masks for flags */
#define CAPS_LOCK 0x01
#define KYPD_APL 0x02
#define CURSOR_APL 0x04
#define N_MARGINBELL 10
#define MAX_TABS 320
#define TAB_ARRAY_SIZE 10 /* number of ints to provide MAX_TABS bits */
typedef unsigned Tabs [TAB_ARRAY_SIZE];
#define BUF_SIZE 4096
typedef struct
{
TKeyboard keyboard; /* terminal keyboard */
TScreen screen; /* terminal screeen */
unsigned flags; /* mode flags */
unsigned initflags; /* initial mode flags */
Tabs tabs; /* tabstops of the terminal */
} Terminal;
/* masks for terminal flags */
#define INVERSE 0x01 /* invert the characters to be output */
#define UNDERLINE 0x02 /* true if underlining */
#define BOLD 0x04
#define WRAPAROUND 0x08
#define REVERSE_VIDEO 0x10 /* true if screen white on black */
#define ORIGIN 0x20 /* true if in origin mode */
#define INSERT 0x40 /* true if in insert mode */
#define SMOOTHSCROLL 0x80 /* true if in smooth scroll mode */
#define AUTOREPEAT 0x100 /* true if in autorepeat mode */
#define IN132COLUMNS 0x200 /* true if in 132 column mode */
#define LINEFEED 0x400
#define REVERSEWRAP 0x800 /* true if reverse wraparound mode */
#define ATTRIBUTES 0x07 /* attributes mask */
#define CHAR 0177
#define VWindow(screen) (screen->fullVwin.window)
#define TextWindow(screen) (screen->fullVwin.window)
#define TWindow(screen) (screen->fullTwin.window)
#define Width(screen) (screen->fullVwin.width)
#define Height(screen) (screen->fullVwin.height)
#define FullWidth(screen) (screen->fullVwin.fullwidth)
#define FullHeight(screen) (screen->fullVwin.fullheight)
#define FontWidth(screen) (screen->fullVwin.f_width)
#define FontHeight(screen) (screen->fullVwin.f_height)
#define TWidth(screen) (screen->fullTwin.width)
#define THeight(screen) (screen->fullTwin.height)
#define TFullWidth(screen) (screen->fullTwin.fullwidth)
#define TFullHeight(screen) (screen->fullTwin.fullheight)
#define TekScale(screen) (screen->fullTwin.tekscale)
#define CursorX(screen,col) ((col) * FontWidth(screen) + screen->border \
+ screen->scrollbar)
#define CursorY(screen,row) ((((row) - screen->topline) * FontHeight(screen)) \
+ screen->border)
#define TWINDOWEVENTS (KeyPressMask | ExposureMask | ButtonPressMask |\
ButtonReleaseMask | StructureNotifyMask |\
EnterWindowMask | LeaveWindowMask | FocusChangeMask)
#define WINDOWEVENTS (TWINDOWEVENTS | PointerMotionMask)
#define TEK_LINK_BLOCK_SIZE 1024
typedef struct Tek_Link
{
struct Tek_Link *next; /* pointer to next TekLink in list
NULL <=> this is last TekLink */
short count;
char *ptr;
char data [TEK_LINK_BLOCK_SIZE];
} TekLink;
/* flags for cursors */
#define OFF 0
#define ON 1
#define CLEAR 0
#define TOGGLE 1
/* flags for color */
#define C_FOREGROUND 0x01
#define C_BACKGROUND 0x02
#define C_FBMASK 0x03
#define C_CURSOR 0x04
#define C_MOUSE 0x08
#define C_BORDER 0x10
/* flags for inhibit */
#define I_LOG 0x01
#define I_SIGNAL 0x02
#define I_TEK 0x04
extern Cursor make_tcross();
extern Cursor make_xterm();
extern Cursor make_wait();
extern Cursor make_arrow();
This archive runs on limited infrastructure. Preserving old code on modern bandwidth. Automated agents are requested to crawl responsibly.