ack/lang/fortran/lib/libI77/dfe.c
1991-10-07 16:59:33 +00:00

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);
}