136 lines
		
	
	
	
		
			2.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			136 lines
		
	
	
	
		
			2.4 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| #include "f2c.h"
 | |
| #include "fio.h"
 | |
| #include "fmt.h"
 | |
| extern int rd_ed(),rd_ned(),y_getc(),y_putc(),y_err();
 | |
| extern int y_rev(), y_rsk(), y_newrec();
 | |
| extern int w_ed(),w_ned();
 | |
| integer s_rdfe(a) cilist *a;
 | |
| {
 | |
| 	int n;
 | |
| 	if(!init) f_init();
 | |
| 	if(n=c_dfe(a))return(n);
 | |
| 	reading=1;
 | |
| 	if(curunit->uwrt && nowreading(curunit))
 | |
| 		err(a->cierr,errno,"read start");
 | |
| 	getn = y_getc;
 | |
| 	doed = rd_ed;
 | |
| 	doned = rd_ned;
 | |
| 	dorevert = donewrec = y_err;
 | |
| 	doend = y_rsk;
 | |
| 	if(pars_f(fmtbuf)<0)
 | |
| 		err(a->cierr,100,"read start");
 | |
| 	fmt_bg();
 | |
| 	return(0);
 | |
| }
 | |
| integer s_wdfe(a) cilist *a;
 | |
| {
 | |
| 	int n;
 | |
| 	if(!init) f_init();
 | |
| 	if(n=c_dfe(a)) return(n);
 | |
| 	reading=0;
 | |
| 	if(curunit->uwrt != 1 && nowwriting(curunit))
 | |
| 		err(a->cierr,errno,"startwrt");
 | |
| 	putn = y_putc;
 | |
| 	doed = w_ed;
 | |
| 	doned= w_ned;
 | |
| 	dorevert = y_err;
 | |
| 	donewrec = y_newrec;
 | |
| 	doend = y_rev;
 | |
| 	if(pars_f(fmtbuf)<0)
 | |
| 		err(a->cierr,100,"startwrt");
 | |
| 	fmt_bg();
 | |
| 	return(0);
 | |
| }
 | |
| integer e_rdfe()
 | |
| {
 | |
| 	(void) en_fio();
 | |
| 	return(0);
 | |
| }
 | |
| integer e_wdfe()
 | |
| {
 | |
| 	(void) en_fio();
 | |
| 	return(0);
 | |
| }
 | |
| c_dfe(a) cilist *a;
 | |
| {
 | |
| 	sequential=0;
 | |
| 	formatted=external=1;
 | |
| 	elist=a;
 | |
| 	cursor=scale=recpos=0;
 | |
| 	if(a->ciunit>MXUNIT || a->ciunit<0)
 | |
| 		err(a->cierr,101,"startchk");
 | |
| 	curunit = &units[a->ciunit];
 | |
| 	if(curunit->ufd==NULL && fk_open(DIR,FMT,a->ciunit))
 | |
| 		err(a->cierr,104,"dfe");
 | |
| 	cf=curunit->ufd;
 | |
| 	if(!curunit->ufmt) err(a->cierr,102,"dfe")
 | |
| 	if(!curunit->useek) err(a->cierr,104,"dfe")
 | |
| 	fmtbuf=a->cifmt;
 | |
| 	(void) fseek(cf,(long)curunit->url * (a->cirec-1),SEEK_SET);
 | |
| 	curunit->uend = 0;
 | |
| 	return(0);
 | |
| }
 | |
| y_rsk()
 | |
| {
 | |
| 	if(curunit->uend || curunit->url <= recpos
 | |
| 		|| curunit->url == 1) return 0;
 | |
| 	do {
 | |
| 		getc(cf);
 | |
| 	} while(++recpos < curunit->url);
 | |
| 	return 0;
 | |
| }
 | |
| y_getc()
 | |
| {
 | |
| 	int ch;
 | |
| 	if(curunit->uend) return(-1);
 | |
| 	if((ch=getc(cf))!=EOF)
 | |
| 	{
 | |
| 		recpos++;
 | |
| 		if(curunit->url>=recpos ||
 | |
| 			curunit->url==1)
 | |
| 			return(ch);
 | |
| 		else	return(' ');
 | |
| 	}
 | |
| 	if(feof(cf))
 | |
| 	{
 | |
| 		curunit->uend=1;
 | |
| 		errno=0;
 | |
| 		return(-1);
 | |
| 	}
 | |
| 	err(elist->cierr,errno,"readingd");
 | |
| }
 | |
| y_putc(c)
 | |
| {
 | |
| 	recpos++;
 | |
| 	if(recpos <= curunit->url || curunit->url==1)
 | |
| 		putc(c,cf);
 | |
| 	else
 | |
| 		err(elist->cierr,110,"dout");
 | |
| 	return(0);
 | |
| }
 | |
| y_rev()
 | |
| {	/*what about work done?*/
 | |
| 	if(curunit->url==1 || recpos==curunit->url)
 | |
| 		return(0);
 | |
| 	while(recpos<curunit->url)
 | |
| 		(*putn)(' ');
 | |
| 	recpos=0;
 | |
| 	return(0);
 | |
| }
 | |
| y_err()
 | |
| {
 | |
| 	err(elist->cierr, 110, "dfe");
 | |
| }
 | |
| 
 | |
| y_newrec()
 | |
| {
 | |
| 	if(curunit->url == 1 || recpos == curunit->url) {
 | |
| 		hiwater = recpos = cursor = 0;
 | |
| 		return(1);
 | |
| 	}
 | |
| 	if(hiwater > recpos)
 | |
| 		recpos = hiwater;
 | |
| 	y_rev();
 | |
| 	hiwater = cursor = 0;
 | |
| 	return(1);
 | |
| }
 |