Home | History | Annotate | Line # | Download | only in wscons
wsemul_vt100var.h revision 1.13
      1  1.13     peter /* $NetBSD: wsemul_vt100var.h,v 1.13 2006/10/09 11:03:43 peter Exp $ */
      2   1.1  drochner 
      3   1.1  drochner /*
      4   1.1  drochner  * Copyright (c) 1998
      5   1.1  drochner  *	Matthias Drochner.  All rights reserved.
      6   1.1  drochner  *
      7   1.1  drochner  * Redistribution and use in source and binary forms, with or without
      8   1.1  drochner  * modification, are permitted provided that the following conditions
      9   1.1  drochner  * are met:
     10   1.1  drochner  * 1. Redistributions of source code must retain the above copyright
     11   1.1  drochner  *    notice, this list of conditions and the following disclaimer.
     12   1.1  drochner  * 2. Redistributions in binary form must reproduce the above copyright
     13   1.1  drochner  *    notice, this list of conditions and the following disclaimer in the
     14   1.1  drochner  *    documentation and/or other materials provided with the distribution.
     15   1.1  drochner  *
     16   1.1  drochner  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
     17   1.1  drochner  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
     18   1.1  drochner  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
     19   1.1  drochner  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
     20   1.1  drochner  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
     21   1.1  drochner  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
     22   1.1  drochner  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
     23   1.1  drochner  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
     24   1.1  drochner  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
     25   1.1  drochner  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
     26   1.1  drochner  *
     27   1.1  drochner  */
     28   1.1  drochner 
     29   1.1  drochner #define	VT100_EMUL_NARGS	10	/* max # of args to a command */
     30   1.1  drochner 
     31   1.1  drochner struct wsemul_vt100_emuldata {
     32   1.1  drochner 	const struct wsdisplay_emulops *emulops;
     33   1.1  drochner 	void *emulcookie;
     34   1.1  drochner 	int scrcapabilities;
     35   1.1  drochner 	u_int nrows, ncols, crow, ccol;
     36   1.9      jmmv 	struct wsdisplay_msgattrs msgattrs;
     37   1.1  drochner 	long defattr;			/* default attribute */
     38   1.1  drochner 
     39   1.1  drochner 	long kernattr;			/* attribute for kernel output */
     40   1.1  drochner 	void *cbcookie;
     41  1.12       chs 	int console;			/* used for DIAGNOSTIC */
     42   1.1  drochner 
     43   1.1  drochner 	u_int state;			/* processing state */
     44   1.1  drochner 	int flags;
     45   1.2  drochner #define VTFL_LASTCHAR	0x001	/* printed last char on line (below cursor) */
     46   1.2  drochner #define VTFL_INSERTMODE	0x002
     47   1.2  drochner #define VTFL_APPLKEYPAD	0x004
     48   1.2  drochner #define VTFL_APPLCURSOR	0x008
     49   1.2  drochner #define VTFL_DECOM	0x010	/* origin mode */
     50   1.2  drochner #define VTFL_DECAWM	0x020	/* auto wrap */
     51   1.2  drochner #define VTFL_CURSORON	0x040
     52   1.2  drochner #define VTFL_NATCHARSET	0x080	/* national replacement charset mode */
     53   1.7  christos #define VTFL_SAVEDCURS	0x100	/* we have a saved cursor state */
     54   1.5   mycroft 	long curattr, bkgdattr;		/* currently used attribute */
     55   1.1  drochner 	int attrflags, fgcol, bgcol;	/* properties of curattr */
     56   1.4  drochner 	u_int scrreg_startrow;
     57   1.4  drochner 	u_int scrreg_nrows;
     58   1.1  drochner 	char *tabs;
     59   1.2  drochner 	char *dblwid;
     60   1.2  drochner 	int dw;
     61   1.2  drochner 
     62   1.2  drochner 	int chartab0, chartab1;
     63   1.2  drochner 	u_int *chartab_G[4];
     64   1.2  drochner 	u_int *isolatin1tab, *decgraphtab, *dectechtab;
     65   1.2  drochner 	u_int *nrctab;
     66   1.2  drochner 	int sschartab; /* single shift */
     67   1.1  drochner 
     68   1.1  drochner 	int nargs;
     69   1.4  drochner 	u_int args[VT100_EMUL_NARGS]; /* numeric command args (CSI/DCS) */
     70   1.1  drochner 
     71   1.2  drochner 	char modif1;	/* {>?} in VT100_EMUL_STATE_CSI */
     72   1.2  drochner 	char modif2;	/* {!"$&} in VT100_EMUL_STATE_CSI */
     73   1.2  drochner 
     74   1.4  drochner 	int designating;	/* substate in VT100_EMUL_STATE_SCS* */
     75   1.1  drochner 
     76   1.1  drochner 	int dcstype;		/* substate in VT100_EMUL_STATE_STRING */
     77   1.1  drochner 	char *dcsarg;
     78   1.1  drochner 	int dcspos;
     79   1.1  drochner #define DCS_MAXLEN 256 /* ??? */
     80   1.1  drochner #define DCSTYPE_TABRESTORE 1 /* DCS2$t */
     81   1.1  drochner 
     82   1.4  drochner 	u_int savedcursor_row, savedcursor_col;
     83   1.5   mycroft 	long savedattr, savedbkgdattr;
     84   1.2  drochner 	int savedattrflags, savedfgcol, savedbgcol;
     85   1.2  drochner 	int savedchartab0, savedchartab1;
     86   1.2  drochner 	u_int *savedchartab_G[4];
     87   1.1  drochner };
     88   1.1  drochner 
     89   1.1  drochner /* some useful utility macros */
     90   1.1  drochner #define	ARG(n)			(edp->args[(n)])
     91   1.2  drochner #define	DEF1_ARG(n)		(ARG(n) ? ARG(n) : 1)
     92   1.3  drochner #define	DEFx_ARG(n, x)		(ARG(n) ? ARG(n) : (x))
     93   1.4  drochner /* the following two can be negative if we are outside the scrolling region */
     94   1.4  drochner #define ROWS_ABOVE	((int)edp->crow - (int)edp->scrreg_startrow)
     95   1.4  drochner #define ROWS_BELOW	((int)(edp->scrreg_startrow + edp->scrreg_nrows) \
     96   1.4  drochner 					- (int)edp->crow - 1)
     97   1.2  drochner #define CHECK_DW do { \
     98   1.2  drochner 	if (edp->dblwid && edp->dblwid[edp->crow]) { \
     99   1.2  drochner 		edp->dw = 1; \
    100   1.2  drochner 		if (edp->ccol > (edp->ncols >> 1) - 1) \
    101   1.2  drochner 			edp->ccol = (edp->ncols >> 1) - 1; \
    102   1.2  drochner 	} else \
    103   1.2  drochner 		edp->dw = 0; \
    104   1.2  drochner } while (0)
    105   1.2  drochner #define NCOLS		(edp->ncols >> edp->dw)
    106   1.2  drochner #define	COLS_LEFT	(NCOLS - edp->ccol - 1)
    107   1.2  drochner #define COPYCOLS(f, t, n) (*edp->emulops->copycols)(edp->emulcookie, \
    108   1.2  drochner 	edp->crow, (f) << edp->dw, (t) << edp->dw, (n) << edp->dw)
    109   1.2  drochner #define ERASECOLS(f, n, a) (*edp->emulops->erasecols)(edp->emulcookie, \
    110   1.2  drochner 	edp->crow, (f) << edp->dw, (n) << edp->dw, a)
    111   1.1  drochner 
    112   1.1  drochner /*
    113   1.1  drochner  * response to primary DA request
    114   1.1  drochner  * operating level: 61 = VT100, 62 = VT200, 63 = VT300
    115   1.1  drochner  * extensions: 1 = 132 cols, 2 = printer port, 6 = selective erase,
    116   1.1  drochner  *	7 = soft charset, 8 = UDKs, 9 = NRC sets
    117   1.1  drochner  * VT100 = "033[?1;2c"
    118   1.1  drochner  */
    119   1.1  drochner #define WSEMUL_VT_ID1 "\033[?62;6c"
    120   1.1  drochner /*
    121   1.1  drochner  * response to secondary DA request
    122   1.1  drochner  * ident code: 24 = VT320
    123   1.1  drochner  * firmware version
    124   1.1  drochner  * hardware options: 0 = no options
    125   1.1  drochner  */
    126   1.1  drochner #define WSEMUL_VT_ID2 "\033[>24;20;0c"
    127   1.1  drochner 
    128   1.6  augustss void wsemul_vt100_reset(struct wsemul_vt100_emuldata *);
    129   1.6  augustss void wsemul_vt100_scrollup(struct wsemul_vt100_emuldata *, int);
    130   1.6  augustss void wsemul_vt100_scrolldown(struct wsemul_vt100_emuldata *, int);
    131   1.6  augustss void wsemul_vt100_ed(struct wsemul_vt100_emuldata *, int);
    132   1.6  augustss void wsemul_vt100_el(struct wsemul_vt100_emuldata *, int);
    133   1.6  augustss void wsemul_vt100_handle_csi(struct wsemul_vt100_emuldata *, u_char);
    134   1.6  augustss void wsemul_vt100_handle_dcs(struct wsemul_vt100_emuldata *);
    135   1.1  drochner 
    136  1.13     peter int wsemul_vt100_translate(void *, keysym_t, const char **);
    137   1.2  drochner 
    138   1.6  augustss void vt100_initchartables(struct wsemul_vt100_emuldata *);
    139   1.6  augustss void vt100_setnrc(struct wsemul_vt100_emuldata *, int);
    140