source: vendor/gcc/3.3.4/libf2c/libI77/sue.c

Last change on this file was 1391, checked in by bird, 21 years ago

GCC v3.3.3 sources.

  • Property cvs2svn:cvs-rev set to 1.1.1.2
  • Property svn:eol-style set to native
  • Property svn:executable set to *
File size: 1.9 KB
Line 
1#include "config.h"
2#include "f2c.h"
3#include "fio.h"
4extern uiolen f__reclen;
5off_t f__recloc;
6
7int
8c_sue (cilist * a)
9{
10 f__external = f__sequential = 1;
11 f__formatted = 0;
12 f__curunit = &f__units[a->ciunit];
13 if (a->ciunit >= MXUNIT || a->ciunit < 0)
14 err (a->cierr, 101, "startio");
15 f__elist = a;
16 if (f__curunit->ufd == NULL && fk_open (SEQ, UNF, a->ciunit))
17 err (a->cierr, 114, "sue");
18 f__cf = f__curunit->ufd;
19 if (f__curunit->ufmt)
20 err (a->cierr, 103, "sue");
21 if (!f__curunit->useek)
22 err (a->cierr, 103, "sue");
23 return (0);
24}
25
26integer
27s_rsue (cilist * a)
28{
29 int n;
30 if (f__init != 1)
31 f_init ();
32 f__init = 3;
33 f__reading = 1;
34 if ((n = c_sue (a)))
35 return (n);
36 f__recpos = 0;
37 if (f__curunit->uwrt && f__nowreading (f__curunit))
38 err (a->cierr, errno, "read start");
39 if (fread ((char *) &f__reclen, sizeof (uiolen), 1, f__cf) != 1)
40 {
41 if (feof (f__cf))
42 {
43 f__curunit->uend = 1;
44 err (a->ciend, EOF, "start");
45 }
46 clearerr (f__cf);
47 err (a->cierr, errno, "start");
48 }
49 return (0);
50}
51
52integer
53s_wsue (cilist * a)
54{
55 int n;
56 if (f__init != 1)
57 f_init ();
58 f__init = 3;
59 if ((n = c_sue (a)))
60 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);
68}
69
70integer
71e_wsue (void)
72{
73 off_t loc;
74 f__init = 1;
75 fwrite ((char *) &f__reclen, sizeof (uiolen), 1, f__cf);
76#ifdef ALWAYS_FLUSH
77 if (fflush (f__cf))
78 err (f__elist->cierr, errno, "write end");
79#endif
80 loc = FTELL (f__cf);
81 FSEEK (f__cf, f__recloc, SEEK_SET);
82 fwrite ((char *) &f__reclen, sizeof (uiolen), 1, f__cf);
83 FSEEK (f__cf, loc, SEEK_SET);
84 return (0);
85}
86
87integer
88e_rsue (void)
89{
90 f__init = 1;
91 FSEEK (f__cf, (off_t) (f__reclen - f__recpos + sizeof (uiolen)), SEEK_CUR);
92 return (0);
93}
Note: See TracBrowser for help on using the repository browser.