Details | Last modification | View Log | RSS feed
Rev | Author | Line No. | Line |
---|---|---|---|
6536 | serge | 1 | /* |
2 | * Copyright (c) 1990 The Regents of the University of California. |
||
3 | * All rights reserved. |
||
4 | * |
||
5 | * Redistribution and use in source and binary forms are permitted |
||
6 | * provided that the above copyright notice and this paragraph are |
||
7 | * duplicated in all such forms and that any documentation, |
||
8 | * advertising materials, and other materials related to such |
||
9 | * distribution and use acknowledge that the software was developed |
||
10 | * by the University of California, Berkeley. The name of the |
||
11 | * University may not be used to endorse or promote products derived |
||
12 | * from this software without specific prior written permission. |
||
13 | * THIS SOFTWARE IS PROVIDED ``AS IS'' AND WITHOUT ANY EXPRESS OR |
||
14 | * IMPLIED WARRANTIES, INCLUDING, WITHOUT LIMITATION, THE IMPLIED |
||
15 | * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE. |
||
16 | */ |
||
17 | |||
18 | /* |
||
19 | FUNCTION |
||
20 | < |
||
21 | |||
22 | INDEX |
||
23 | fgetpos |
||
24 | INDEX |
||
25 | _fgetpos_r |
||
26 | |||
27 | ANSI_SYNOPSIS |
||
28 | #include |
||
29 | int fgetpos(FILE *restrict <[fp]>, fpos_t *restrict <[pos]>); |
||
30 | int _fgetpos_r(struct _reent *<[ptr]>, FILE *restrict <[fp]>, fpos_t *restrict <[pos]>); |
||
31 | |||
32 | TRAD_SYNOPSIS |
||
33 | #include |
||
34 | int fgetpos(<[fp]>, <[pos]>) |
||
35 | FILE *<[fp]>; |
||
36 | fpos_t *<[pos]>; |
||
37 | |||
38 | int _fgetpos_r(<[ptr]>, <[fp]>, <[pos]>) |
||
39 | struct _reent *<[ptr]>; |
||
40 | FILE *<[fp]>; |
||
41 | fpos_t *<[pos]>; |
||
42 | |||
43 | DESCRIPTION |
||
44 | Objects of type < |
||
45 | of the file your program has already read. Many of the < |
||
46 | depend on this position, and many change it as a side effect. |
||
47 | |||
48 | You can use < |
||
49 | identified by <[fp]>; < |
||
50 | representing that position at <<*<[pos]>>>. Later, you can |
||
51 | use this value with < |
||
52 | position. |
||
53 | |||
54 | In the current implementation, < |
||
55 | count to represent the file position; this is the same number that |
||
56 | would be returned by < |
||
57 | |||
58 | RETURNS |
||
59 | < |
||
60 | result is <<1>>. Failure occurs on streams that do not support |
||
61 | positioning; the global < |
||
62 | value < |
||
63 | |||
64 | PORTABILITY |
||
65 | < |
||
66 | value it records is not specified beyond requiring that it be |
||
67 | acceptable as an argument to < |
||
68 | conforming C implementations may return a different result from |
||
69 | < |
||
70 | |||
71 | No supporting OS subroutines are required. |
||
72 | */ |
||
73 | |||
74 | #include <_ansi.h> |
||
75 | #include |
||
76 | #include |
||
77 | |||
78 | int |
||
79 | _DEFUN(_fgetpos_r, (ptr, fp, pos), |
||
80 | struct _reent * ptr _AND |
||
81 | FILE *__restrict fp _AND |
||
82 | _fpos_t *__restrict pos) |
||
83 | { |
||
84 | *pos = _ftell_r (ptr, fp); |
||
85 | |||
86 | if (*pos != -1) |
||
87 | { |
||
88 | return 0; |
||
89 | } |
||
90 | return 1; |
||
91 | } |
||
92 | |||
93 | #ifndef _REENT_ONLY |
||
94 | |||
95 | int |
||
96 | _DEFUN(fgetpos, (fp, pos), |
||
97 | FILE *__restrict fp _AND |
||
98 | _fpos_t *__restrict pos) |
||
99 | { |
||
100 | return _fgetpos_r (_REENT, fp, pos); |
||
101 | } |
||
102 | |||
103 | #endif /* !_REENT_ONLY */[pos]>*<[pos]><*<[pos]> |