2001-05-17 02:59:29 +08:00
|
|
|
#include "config.h"
|
1998-02-01 09:37:08 +08:00
|
|
|
#include "f2c.h"
|
|
|
|
#include "fio.h"
|
|
|
|
|
|
|
|
static FILE *
|
|
|
|
#ifdef KR_headers
|
|
|
|
unit_chk(Unit, who) integer Unit; char *who;
|
|
|
|
#else
|
|
|
|
unit_chk(integer Unit, char *who)
|
|
|
|
#endif
|
|
|
|
{
|
|
|
|
if (Unit >= MXUNIT || Unit < 0)
|
|
|
|
f__fatal(101, who);
|
|
|
|
return f__units[Unit].ufd;
|
|
|
|
}
|
|
|
|
|
2001-07-11 04:39:40 +08:00
|
|
|
integer
|
1998-02-01 09:37:08 +08:00
|
|
|
#ifdef KR_headers
|
|
|
|
G77_ftell_0 (Unit) integer *Unit;
|
|
|
|
#else
|
|
|
|
G77_ftell_0 (integer *Unit)
|
|
|
|
#endif
|
|
|
|
{
|
|
|
|
FILE *f;
|
2001-07-11 04:39:40 +08:00
|
|
|
return (f = unit_chk(*Unit, "ftell")) ? (integer) FTELL(f) : -1L;
|
1998-02-01 09:37:08 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
integer
|
|
|
|
#ifdef KR_headers
|
|
|
|
G77_fseek_0 (Unit, offset, xwhence) integer *Unit, *offset, *xwhence;
|
|
|
|
#else
|
|
|
|
G77_fseek_0 (integer *Unit, integer *offset, integer *xwhence)
|
|
|
|
#endif
|
|
|
|
{
|
|
|
|
FILE *f;
|
|
|
|
int w = (int)*xwhence;
|
|
|
|
#ifdef SEEK_SET
|
|
|
|
static int wohin[3] = { SEEK_SET, SEEK_CUR, SEEK_END };
|
|
|
|
#endif
|
|
|
|
if (w < 0 || w > 2)
|
|
|
|
w = 0;
|
|
|
|
#ifdef SEEK_SET
|
|
|
|
w = wohin[w];
|
|
|
|
#endif
|
|
|
|
return !(f = unit_chk(*Unit, "fseek"))
|
2001-07-11 04:39:40 +08:00
|
|
|
|| FSEEK(f, (off_t) *offset, w) ? 1 : 0;
|
1998-02-01 09:37:08 +08:00
|
|
|
}
|