V10/630/src/frameop.c

Compare this file to the similar file:
Show the results in this format:

#include <jerq.h>
#include <layer.h>
#include <queue.h>
#include <jerqproc.h>
#include <font.h>
#include "frame.h"

Point endpoint;
nexttab(t, x)
	Frame *t;
{
	int eightspaces=P->defaultfont->info[' '].width<<3;
	register xx=x-t->rect.origin.x;
	return(xx-(xx%eightspaces)+eightspaces+t->rect.origin.x);
}
void opshow();
int complete;
frameop(t, op, pt, cp, n)
	register Frame *t;
	register void (*op)();
	Point pt;
	register unsigned char *cp;
	register n;
{
	register i, j;
	Point startpt;
	register unsigned char *startcp;
	complete=0;
	endpoint=pt;
	i=0;	/* Not in for(;;) because of \t's */
    Top_of_loop:
	endpoint=pt;
	for(j=0,startpt=pt,startcp=cp; ; i++,j++,cp++){
    Continue:
		if(i>=n)
			break;
		if(*cp=='\n'){
			i++, j++, cp++;
	    Emit_newline:
			pt.x=t->rect.corner.x;
			endpoint=pt;
			/* must do this even if j==0 */
			(*op)(t, startpt, pt, startcp, j);
			j=0;
			startpt.x=t->rect.origin.x;
			startpt.y+=newlnsz;
			if(startpt.y >= t->rect.corner.y)	/* off screen */
				return;
			pt=startpt;
			startcp=cp;
			goto Continue;
		}else if(*cp == '\t'){
			if(j > 0){
				/* Emit what's saved up */
				(*op)(t, startpt, pt, startcp, j);
				goto Top_of_loop;
			}
			if((pt.x=nexttab(t, pt.x)) > t->rect.corner.x)
				goto Emit_newline;
			(*op)(t, startpt, pt, cp++, 1);
			i++;
			goto Top_of_loop;
		}else if(*cp!='\r' && *cp<=P->defaultfont->n)
			if((pt.x+=cwidth(*cp)) > t->rect.corner.x)
				goto Emit_newline;
	}
	if(startpt.y < t->rect.corner.y){
		endpoint=pt;
		(*op)(t, startpt, pt, startcp, j);
		complete=1;
	}
}
char genbuf[100];
void
opdraw(t, p, q, cp, n)
	Frame *t;
	Point p, q;
	register unsigned char *cp;
	register n;
{
	register char *gp=genbuf;
	while(n--){
		if(*cp!='\n' && *cp!='\t' && *cp!='\r')
			*gp++=*cp;
		cp++;
	}
	*gp=0;
	p.x++;
	string(P->defaultfont, genbuf, D, p, F_XOR);
}
draw(t, p, s, n)
	Frame *t;
	Point p;
	char *s;
	int n;
{
	frameop(t, opdraw, p, s, n);
}

int	F_rectf;
/*ARGSUSED*/
void
oprectf(t, p, q, str, n)
	register Frame *t;
	Point p, q;
	char *str;
	short n;
{
	Urectf(D, Rpt(p, Pt(q.x, q.y+newlnsz)), F_rectf);
}

/*ARGSUSED*/
void
opclear(t, p, q, str, n)
	register Frame *t;
	Point p, q;
	char *str;
	short n;
{
	clear(Rpt(p, Pt(q.x, q.y+newlnsz)), 1);
}

selectf(t, f)
	register Frame *t;
{
	F_rectf=f;
	frameop(t, oprectf, ptofchar(t, t->s1), t->str.s+t->s1, t->s2-t->s1);
}
void
opnull()
{}
rXOR(r)	/* a space-saving routine */
	Rectangle r;
{
	lrectf(D, r, F_XOR);
}
Rectf(r, f)
	Rectangle r;
	Code f;
{
	lrectf(D, r, f);
}