-
Notifications
You must be signed in to change notification settings - Fork 0
/
c_fgetpos.c
52 lines (37 loc) · 1.52 KB
/
c_fgetpos.c
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
////////////////////////////////////////////////////////////////////////////////
#include <stdio.h>
/*
Get STREAM's position.
istat = 0 if OK,
= nonzero on error.
Introduced by ISO C standard.
*/
void c_fgetpos_ ( FILE **fp, fpos_t *pos, int *istat )
{
*istat = fgetpos ( *fp, pos ) ;
}
//
#include <stdint.h>
void c_fgetpos_intref_ ( intptr_t *iptr, fpos_t *pos, int *istat )
{
*istat = fgetpos ( (FILE *) (*iptr), pos ) ;
}
/*
The fgetpos() function stores the current value of the file's position
indicator in the object pointed to by POS. This value can be used in a
later call to fsetpos() to reposition the stream to that location.
NOTE: fpos_t = 16, hence POS in integer(kind=16) is very large.
There are three ways to position a standard I/O stream:
1. The two functions ftell() and fseek(). They have been around since
Version 7, but they assume that a file’s position can be stored in a long
integer (i.e. 8 bytes).
2. The two functions ftello() and fseeko(). They were introduced in the
Single UNIX Specification to allow for file offsets that might not fit in
a long integer. They replace the long integer with the off_t data type,
i.e. 8 bytes.
3. The two functions fgetpos() and fsetpos(). They were introduced by
ISO C. They use an abstract data type, fpos_t (18 bytes), that records
a file's position. This datatype can be made as big as necessary to
record a file's position.
*/
//