Daily bump.
[official-gcc.git] / libf2c / libI77 / sue.c
blob8865054b10b7cddf739052a2da21dbebdc61f8e2
1 #include "config.h"
2 #include "f2c.h"
3 #include "fio.h"
4 extern uiolen f__reclen;
5 off_t f__recloc;
7 #ifdef KR_headers
8 c_sue(a) cilist *a;
9 #else
10 c_sue(cilist *a)
11 #endif
13 f__external=f__sequential=1;
14 f__formatted=0;
15 f__curunit = &f__units[a->ciunit];
16 if(a->ciunit >= MXUNIT || a->ciunit < 0)
17 err(a->cierr,101,"startio");
18 f__elist=a;
19 if(f__curunit->ufd==NULL && fk_open(SEQ,UNF,a->ciunit))
20 err(a->cierr,114,"sue");
21 f__cf=f__curunit->ufd;
22 if(f__curunit->ufmt) err(a->cierr,103,"sue");
23 if(!f__curunit->useek) err(a->cierr,103,"sue");
24 return(0);
26 #ifdef KR_headers
27 integer s_rsue(a) cilist *a;
28 #else
29 integer s_rsue(cilist *a)
30 #endif
32 int n;
33 if(f__init != 1) f_init();
34 f__init = 3;
35 f__reading=1;
36 if(n=c_sue(a)) return(n);
37 f__recpos=0;
38 if(f__curunit->uwrt && f__nowreading(f__curunit))
39 err(a->cierr, errno, "read start");
40 if(fread((char *)&f__reclen,sizeof(uiolen),1,f__cf)
41 != 1)
42 { if(feof(f__cf))
43 { f__curunit->uend = 1;
44 err(a->ciend, EOF, "start");
46 clearerr(f__cf);
47 err(a->cierr, errno, "start");
49 return(0);
51 #ifdef KR_headers
52 integer s_wsue(a) cilist *a;
53 #else
54 integer s_wsue(cilist *a)
55 #endif
57 int n;
58 if(f__init != 1) f_init();
59 f__init = 3;
60 if(n=c_sue(a)) return(n);
61 f__reading=0;
62 f__reclen=0;
63 if(f__curunit->uwrt != 1 && f__nowwriting(f__curunit))
64 err(a->cierr, errno, "write start");
65 f__recloc=FTELL(f__cf);
66 FSEEK(f__cf,(off_t)sizeof(uiolen),SEEK_CUR);
67 return(0);
69 integer e_wsue(Void)
70 { off_t loc;
71 f__init = 1;
72 fwrite((char *)&f__reclen,sizeof(uiolen),1,f__cf);
73 #ifdef ALWAYS_FLUSH
74 if (fflush(f__cf))
75 err(f__elist->cierr, errno, "write end");
76 #endif
77 loc=FTELL(f__cf);
78 FSEEK(f__cf,f__recloc,SEEK_SET);
79 fwrite((char *)&f__reclen,sizeof(uiolen),1,f__cf);
80 FSEEK(f__cf,loc,SEEK_SET);
81 return(0);
83 integer e_rsue(Void)
85 f__init = 1;
86 FSEEK(f__cf,(off_t)(f__reclen-f__recpos+sizeof(uiolen)),SEEK_CUR);
87 return(0);