string.h is ANSI C include file
[unix-history] / usr / src / usr.bin / f77 / libI77 / inquire.c
/*
* Copyright (c) 1980 Regents of the University of California.
* All rights reserved. The Berkeley software License Agreement
* specifies the terms and conditions for redistribution.
*
* @(#)inquire.c 5.2 %G%
*/
/*
* inquire.c - f77 i/o inquire statement routine
*/
#include "fio.h"
f_inqu(a) inlist *a;
{ char *byfile;
int i;
int exist;
unit *p;
char buf[256], *s;
long x_inode;
elist = NO;
lfname = a->infile;
lunit = a->inunit;
external = YES;
p = NULL;
if(byfile=a->infile)
{
g_char(a->infile,a->infilen,buf);
if((x_inode=inode(buf))==-1)
{ exist = NO; /* file doesn't exist */
}
else
{ exist = YES; /* file does exist */
for(i=0;i<MXUNIT;i++)
if(units[i].ufd && (units[i].uinode==x_inode))
{
p = &units[i];
break;
}
}
}
else
{
if (not_legal(lunit))
{ exist = NO; /* unit doesn't exist */
}
else
{ exist = YES;
if (units[lunit].ufd)
{ p= &units[lunit];
lfname = p->ufnm;
}
}
}
if(a->inex) *a->inex = exist;
if(a->inopen) *a->inopen=(p!=NULL);
if(a->innum) *a->innum = byfile?(p?(p-units):-1):lunit;
if(a->innamed) *a->innamed= (byfile || (p && p->ufnm));
if(a->inname)
{
if(byfile) s = buf;
else if(p && p->ufnm) s = p->ufnm;
else s="";
b_char(s,a->inname,a->innamlen);
}
if(a->inacc)
{
if(!p) s = "unknown";
else if(p->url) s = "direct";
else s = "sequential";
b_char(s,a->inacc,a->inacclen);
}
if(a->inseq)
{
if(!p) s = "unknown";
else s = (p && !p->url)? "yes" : "no";
b_char(s,a->inseq,a->inseqlen);
}
if(a->indir)
{
if(!p) s = "unknown";
else s = (p && p->useek && p->url)? "yes" : "no";
b_char(s,a->indir,a->indirlen);
}
if(a->inform)
{ if(p)
{
#ifndef KOSHER
if(p->uprnt) s = "print"; /*** NOT STANDARD FORTRAN ***/
else
#endif
s = p->ufmt?"formatted":"unformatted";
}
else s = "unknown";
b_char(s,a->inform,a->informlen);
}
if(a->infmt)
{
if (p) s= p->ufmt? "yes" : "no";
else s= "unknown";
b_char(s,a->infmt,a->infmtlen);
}
if(a->inunf)
{
if (p) s= p->ufmt? "no" : "yes";
else s= "unknown";
b_char(s,a->inunf,a->inunflen);
}
if(a->inrecl) *a->inrecl = p ? p->url : -1;
if(a->innrec) {
if(p && p->url)
*a->innrec = ((ftell(p->ufd) + p->url - 1)/p->url) + 1;
else
*a->innrec = -1;
}
if(a->inblank)
{
if( p && p->ufmt)
s = p->ublnk ? "zero" : "null" ;
else
s = "unknown";
b_char(s,a->inblank,a->inblanklen);
}
return(OK);
}