mirror of https://github.com/macssh/macssh.git
cleanup. fixed crash
This commit is contained in:
parent
72f42f1086
commit
84a61847f8
|
@ -50,6 +50,8 @@ static RGLINK RG[TEK_DEVICE_MAX] = {
|
||||||
|
|
||||||
extern WindRec *screens;
|
extern WindRec *screens;
|
||||||
|
|
||||||
|
Boolean gTekCopying = FALSE;
|
||||||
|
|
||||||
static fontnum(short vw, short n);
|
static fontnum(short vw, short n);
|
||||||
static storexy(short vw, short x, short y);
|
static storexy(short vw, short x, short y);
|
||||||
static joinup(short hi, short lo, short e);
|
static joinup(short hi, short lo, short e);
|
||||||
|
@ -385,16 +387,14 @@ static short VGcheck(short dnum)
|
||||||
short VGnewwin
|
short VGnewwin
|
||||||
(
|
(
|
||||||
short device, /* number of RG device to use */
|
short device, /* number of RG device to use */
|
||||||
short theVS
|
short theVS,
|
||||||
|
short tek4105,
|
||||||
|
short tekclear
|
||||||
)
|
)
|
||||||
{
|
{
|
||||||
short vw = 0;
|
short vw = 0;
|
||||||
short theScrn;
|
short theScrn;
|
||||||
|
|
||||||
theScrn = findbyVS(theVS);
|
|
||||||
if (theScrn < 0)
|
|
||||||
return(-1);
|
|
||||||
|
|
||||||
while ((vw < MAXVG) && (VGwin[vw] != nil)) vw++;
|
while ((vw < MAXVG) && (VGwin[vw] != nil)) vw++;
|
||||||
if (vw == MAXVG)
|
if (vw == MAXVG)
|
||||||
return(-1);
|
return(-1);
|
||||||
|
@ -415,7 +415,8 @@ short VGnewwin
|
||||||
VGwin[vw]->RGdevice = device;
|
VGwin[vw]->RGdevice = device;
|
||||||
VGwin[vw]->RGnum = (*RG[device].newwin)();
|
VGwin[vw]->RGnum = (*RG[device].newwin)();
|
||||||
|
|
||||||
VGwin[vw]->TEKtype = screens[theScrn].tektype; // 0 = 4014, 1 = 4105
|
VGwin[vw]->TEKtype = (tek4105 != 0); // 0 = 4014, 1 = 4105
|
||||||
|
VGwin[vw]->tekclear = tekclear;
|
||||||
|
|
||||||
if (VGwin[vw]->RGnum < 0)
|
if (VGwin[vw]->RGnum < 0)
|
||||||
{
|
{
|
||||||
|
@ -458,6 +459,25 @@ void VGclose(short vw)
|
||||||
VGwin[vw] = nil;
|
VGwin[vw] = nil;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/* return this window's tek emulation type */
|
||||||
|
short VGgettektype(short vw)
|
||||||
|
{
|
||||||
|
if (VGcheck(vw)) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
return VGwin[vw]->TEKtype;
|
||||||
|
}
|
||||||
|
|
||||||
|
/* return this window's tek clear flag */
|
||||||
|
short VGgettekclear(short vw)
|
||||||
|
{
|
||||||
|
if (VGcheck(vw)) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
return VGwin[vw]->tekclear;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
/* Detach window from its current device and attach it to the
|
/* Detach window from its current device and attach it to the
|
||||||
* specified device. Returns negative number if unable to do so.
|
* specified device. Returns negative number if unable to do so.
|
||||||
* Sample application: switching an image from #9 to Hercules.
|
* Sample application: switching an image from #9 to Hercules.
|
||||||
|
@ -529,7 +549,6 @@ void VGdumpstore(short vw, short (*func )(short))
|
||||||
*/
|
*/
|
||||||
void VGdraw(short vw, char c) /* the latest input char */
|
void VGdraw(short vw, char c) /* the latest input char */
|
||||||
{
|
{
|
||||||
short sn;
|
|
||||||
char cmd;
|
char cmd;
|
||||||
char value;
|
char value;
|
||||||
char goagain; /* true means go thru the function a second time */
|
char goagain; /* true means go thru the function a second time */
|
||||||
|
@ -537,6 +556,7 @@ void VGdraw(short vw, char c) /* the latest input char */
|
||||||
RgnHandle PanelRgn;
|
RgnHandle PanelRgn;
|
||||||
struct VGWINTYPE *vp;
|
struct VGWINTYPE *vp;
|
||||||
pointlist temppoint;
|
pointlist temppoint;
|
||||||
|
GrafPtr savePort;
|
||||||
|
|
||||||
if (VGcheck(vw)) {
|
if (VGcheck(vw)) {
|
||||||
return;
|
return;
|
||||||
|
@ -544,10 +564,6 @@ void VGdraw(short vw, char c) /* the latest input char */
|
||||||
|
|
||||||
vp = VGwin[vw]; /* BYU */
|
vp = VGwin[vw]; /* BYU */
|
||||||
|
|
||||||
sn = findbyVS(vp->theVS);
|
|
||||||
if (sn < 0)
|
|
||||||
return;
|
|
||||||
|
|
||||||
temp[0] = c;
|
temp[0] = c;
|
||||||
temp[1] = (char) 0;
|
temp[1] = (char) 0;
|
||||||
|
|
||||||
|
@ -824,7 +840,7 @@ void VGdraw(short vw, char c) /* the latest input char */
|
||||||
state[vw] = DONE;
|
state[vw] = DONE;
|
||||||
break;
|
break;
|
||||||
case 12: /* form feed = clrscr */
|
case 12: /* form feed = clrscr */
|
||||||
if (sn >= 0 && screens[sn].tekclear) {
|
if (vp->tekclear) {
|
||||||
VGpage(vw);
|
VGpage(vw);
|
||||||
VGclrstor(vw);
|
VGclrstor(vw);
|
||||||
}
|
}
|
||||||
|
@ -983,6 +999,7 @@ void VGdraw(short vw, char c) /* the latest input char */
|
||||||
{
|
{
|
||||||
if (vp->TEKPanel)
|
if (vp->TEKPanel)
|
||||||
{
|
{
|
||||||
|
|
||||||
if ((vp->current->x != vp->savx) ||
|
if ((vp->current->x != vp->savx) ||
|
||||||
(vp->current->y != vp->savy))
|
(vp->current->y != vp->savy))
|
||||||
{
|
{
|
||||||
|
@ -1020,6 +1037,7 @@ void VGdraw(short vw, char c) /* the latest input char */
|
||||||
vp->TEKPanel = (pointlist) NULL;
|
vp->TEKPanel = (pointlist) NULL;
|
||||||
vp->curx = vp->savx;
|
vp->curx = vp->savx;
|
||||||
vp->cury = vp->savy;
|
vp->cury = vp->savy;
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
state[vw] = DONE;
|
state[vw] = DONE;
|
||||||
|
@ -1268,16 +1286,19 @@ void VGdraw(short vw, char c) /* the latest input char */
|
||||||
state[vw] = CMD0;
|
state[vw] = CMD0;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
if (vp->mode == ALPHA)
|
if (vp->mode == ALPHA) {
|
||||||
{
|
|
||||||
state[vw] = DONE;
|
state[vw] = DONE;
|
||||||
if (! vp->TEKtype)
|
if (! vp->TEKtype) {
|
||||||
drawc(vw,(short) c);
|
drawc(vw,(short) c);
|
||||||
else
|
} else {
|
||||||
{
|
// not while copying a picture !!!
|
||||||
VSwrite(vp->theVS,&c,1);
|
if (!gTekCopying) {
|
||||||
|
GetPort(&savePort);
|
||||||
|
VSwrite(vp->theVS, &c, 1);
|
||||||
|
SetPort(savePort);
|
||||||
TEKunstore(VGstore[vw]);
|
TEKunstore(VGstore[vw]);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
else if ((vp->mode == DRAW) && cmd)
|
else if ((vp->mode == DRAW) && cmd)
|
||||||
|
|
Loading…
Reference in New Issue