--- ray/src/rt/aed.c 1989/10/03 11:10:02 1.3 +++ ray/src/rt/aed.c 2003/02/25 02:47:22 2.4 @@ -1,15 +1,12 @@ -/* Copyright (c) 1987 Regents of the University of California */ - #ifndef lint -static char SCCSid[] = "$SunId$ LBL"; +static const char RCSid[] = "$Id: aed.c,v 2.4 2003/02/25 02:47:22 greg Exp $"; #endif - /* * aed.c - driver for AED 512 terminal. - * - * 2/2/87 */ +#include "copyright.h" + #include #include "driver.h" @@ -52,28 +49,26 @@ static char SCCSid[] = "$SunId$ LBL"; #define MINPIX 8 /* minimum hardware color */ #define NCOLS 512 /* maximum # columns for output */ -#define NROWS 512-COMHT /* maximum # rows for output */ +#define NROWS 483-COMHT /* maximum # rows for output */ #define COMHT 16 /* height of command line */ #define COMCW 63 /* maximum chars on command line */ -int anewcolr(); - int aed_close(), aed_clear(), aed_paintr(), aed_getcur(), aed_comout(), aed_errout(); static struct driver aed_driver = { aed_close, aed_clear, aed_paintr, aed_getcur, - aed_comout, NULL, - NCOLS, NROWS + aed_comout, NULL, NULL, + 1.0, NCOLS, NROWS }; struct driver * -aed_init(name) /* open AED */ -char *name; +aed_init(name, id) /* open AED */ +char *name, *id; { if (ttyset(&aed_driver, fileno(stdin)) < 0) { /* set tty driver */ - stderr_v("cannot access terminal\n"); + eputs("cannot access terminal\n"); return(NULL); } command(RST); /* reset AED */ @@ -88,11 +83,14 @@ char *name; byte(BLK); byte(WHT); byte(15); command(SCP); byte('+'); byte(0); byte(1); - make_cmap(GAMMA); /* make color map */ - errvec = aed_errout; /* set error vector */ - cmdvec = aed_errout; - if (wrnvec != NULL) - wrnvec = aed_errout; + make_gmap(GAMMA); /* make color map */ + erract[USER].pf = /* set error vector */ + erract[SYSTEM].pf = + erract[INTERNAL].pf = + erract[CONSISTENCY].pf = aed_errout; + erract[COMMAND].pf = aed_errout; + if (erract[WARNING].pf != NULL) + erract[WARNING].pf = aed_errout; return(&aed_driver); } @@ -100,10 +98,13 @@ char *name; static aed_close() /* close AED */ { - errvec = stderr_v; /* reset error vector */ - cmdvec = NULL; - if (wrnvec != NULL) - wrnvec = stderr_v; + erract[USER].pf = /* reset error vector */ + erract[SYSTEM].pf = + erract[INTERNAL].pf = + erract[CONSISTENCY].pf = eputs; + erract[COMMAND].pf = NULL; + if (erract[WARNING].pf != NULL) + erract[WARNING].pf = wputs; aedsetcap(0, 0); /* go to bottom */ command(SEC); byte(WHT); /* white text */ @@ -119,7 +120,7 @@ aed_clear(x, y) /* clear AED */ int x, y; { command(FFD); - new_ctab(NCOLORS, anewcolr); /* init color table */ + new_ctab(NCOLORS); /* init color table */ flush(); } @@ -129,9 +130,10 @@ aed_paintr(col, xmin, ymin, xmax, ymax) /* paint a re COLOR col; int xmin, ymin, xmax, ymax; { + extern int anewcolr(); int ndx; - ndx = get_pixel(col); /* may call anewcolr() */ + ndx = get_pixel(col, anewcolr); /* calls anewcolr() */ command(SEC); /* draw rectangle */ byte(ndx+MINPIX); aedsetcap(xmin, ymin+COMHT);