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

70 lines
1.1 KiB
C

/* read sequential formatted external */
#include "f2c.h"
#include "fio.h"
#include "fmt.h"
extern int x_getc(),rd_ed(),rd_ned();
extern int x_endp(),x_rev(),xrd_SL();
integer s_rsfe(a) cilist *a; /* start */
{ int n;
if(!init) f_init();
if(n=c_sfe(a)) return(n);
reading=1;
sequential=1;
formatted=1;
external=1;
elist=a;
cursor=recpos=0;
scale=0;
fmtbuf=a->cifmt;
curunit= &units[a->ciunit];
cf=curunit->ufd;
if(pars_f(fmtbuf)<0) err(a->cierr,100,"startio");
getn= x_getc;
doed= rd_ed;
doned= rd_ned;
fmt_bg();
doend=x_endp;
donewrec=xrd_SL;
dorevert=x_rev;
cblank=curunit->ublnk;
cplus=0;
if(curunit->uwrt && nowreading(curunit))
err(a->cierr,errno,"read start");
return(0);
}
xrd_SL()
{ int ch;
if(!curunit->uend)
while((ch=getc(cf))!='\n' && ch!=EOF);
cursor=recpos=0;
return(1);
}
x_getc()
{ int ch;
if(curunit->uend) return(EOF);
ch = getc(cf);
if(ch!=EOF && ch!='\n')
{ recpos++;
return(ch);
}
if(ch=='\n')
{ (void) ungetc(ch,cf);
return(ch);
}
if(curunit->uend || feof(cf))
{ errno=0;
curunit->uend=1;
return(-1);
}
return(-1);
}
x_endp()
{
(void) xrd_SL();
return(0);
}
x_rev()
{
(void) xrd_SL();
return(0);
}