--- ray/src/rt/vga.c 1992/10/13 17:42:22 2.3 +++ ray/src/rt/vga.c 2004/03/30 16:13:01 2.10 @@ -1,55 +1,61 @@ -/* Copyright (c) 1992 Regents of the University of California */ - #ifndef lint -static char SCCSid[] = "$SunId$ LBL"; +static const char RCSid[] = "$Id: vga.c,v 2.10 2004/03/30 16:13:01 schorsch Exp $"; #endif - /* * vga.c - driver for VGA graphics adaptor under MS-DOS */ -#include +#include "copyright.h" #include +#include "standard.h" #include "driver.h" - #include "color.h" #define GAMMA 2.2 /* exponent for color correction */ -int vga_close(), vga_clear(), vga_paintr(), vga_comout(), vga_errout(), - vga_comin(); +static struct driver * vga_init(char *name, char *id); +static void vga_errout(char *msg); +static dr_newcolrf_t vgacolr; +static dr_closef_t vga_close; +static dr_clearf_t vga_clear; +static dr_paintrf_t vga_paintr; +static dr_comoutf_t vga_comout; +static dr_cominf_t vga_comin; + static struct driver vga_driver = { vga_close, vga_clear, vga_paintr, NULL, vga_comout, vga_comin, NULL, 1.0 }; static char fatalerr[128]; - static struct videoconfig config; -extern char *getenv(); -struct driver * -vga_init(name, id) /* open VGA */ -char *name, *id; +static struct driver * +vga_init( /* open VGA */ + char *name, + char *id +) { - static short mode_pref[] = {_XRES256COLOR, _SVRES256COLOR, + static short mode_pref[] = {_MRES256COLOR, -1}; + static short smode_pref[] = {_XRES256COLOR, _SVRES256COLOR, _VRES256COLOR, _MRES256COLOR, -1}; char *ep; - register int i; + register short *mp; - for (i = 0; mode_pref[i] != -1; i++) - if (_setvideomode(mode_pref[i])) + mp = !strcmp(name, "vga") ? mode_pref : smode_pref; + for ( ; *mp != -1; mp++) + if (_setvideomode(*mp)) break; - if (mode_pref[i] == -1) { + if (*mp == -1) { _setvideomode(_DEFAULTMODE); - stderr_v(name); - stderr_v(": card not present or insufficient VGA memory\n"); + eputs(name); + eputs(": card not present or insufficient VGA memory\n"); return(NULL); } _getvideoconfig(&config); @@ -74,43 +80,54 @@ char *name, *id; _remappalette(1, _BRIGHTWHITE); _settextcolor(1); ms_gcinit(&vga_driver); - errvec = vga_errout; - cmdvec = vga_comout; - if (wrnvec != NULL) - wrnvec = vga_comout; + erract[USER].pf = + erract[SYSTEM].pf = + erract[INTERNAL].pf = + erract[CONSISTENCY].pf = vga_errout; + erract[COMMAND].pf = vga_comout; + if (erract[WARNING].pf != NULL) + erract[WARNING].pf = vga_comout; return(&vga_driver); } -static -vga_close() /* close VGA */ +static void +vga_close(void) /* close VGA */ { + ms_gcdone(&vga_driver); _setvideomode(_DEFAULTMODE); - errvec = stderr_v; /* reset error vectors */ - 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; if (fatalerr[0]) - stderr_v(fatalerr); /* repeat error message */ + eputs(fatalerr); /* repeat error message */ } -static -vga_clear(x, y) /* clear VGA */ -int x, y; +static void +vga_clear( /* clear VGA */ + int x, + int y +) { _clearscreen(_GCLEARSCREEN); new_ctab(config.numcolors-2); /* init color table */ } -static -vga_paintr(col, xmin, ymin, xmax, ymax) /* paint a rectangle */ -COLOR col; -int xmin, ymin, xmax, ymax; +static void +vga_paintr( /* paint a rectangle */ + COLOR col, + int xmin, + int ymin, + int xmax, + int ymax +) { - extern int vgacolr(); - _setcolor(get_pixel(col, vgacolr)+2); _rectangle(_GFILLINTERIOR, xmin, vga_driver.ysiz-ymax, xmax-1, vga_driver.ysiz-1-ymin); @@ -118,9 +135,10 @@ int xmin, ymin, xmax, ymax; } -static -vga_comout(s) /* put s to text output */ -register char *s; +static void +vga_comout( /* put s to text output */ + register char *s +) { struct rccoord tpos; char buf[128]; @@ -150,9 +168,10 @@ register char *s; } -static -vga_errout(msg) -register char *msg; +static void +vga_errout( + register char *msg +) { static char *fep = fatalerr; @@ -165,10 +184,11 @@ register char *msg; } -static -vga_comin(buf, prompt) /* get input line from console */ -char *buf; -char *prompt; +static void +vga_comin( /* get input line from console */ + char *buf, + char *prompt +) { extern int getch(); @@ -179,10 +199,13 @@ char *prompt; } -static -vgacolr(index, r, g, b) /* enter a color into our table */ -int index; -int r, g, b; +static void +vgacolr( /* enter a color into our table */ + int index, + int r, + int g, + int b +) { register long cl;