fixed declaration for MAXERR. DLW
[unix-history] / usr / src / usr.bin / f77 / libI77 / close.c
CommitLineData
e798709f 1/*
3bbbaca0 2char id_close[] = "@(#)close.c 1.2";
e798709f
DW
3 *
4 * close.c - f77 file close, flush, exit routines
5 */
6
7#include "fio.h"
8
9#define FROM_OPEN '\1'
10
11f_clos(a) cllist *a;
12{ unit *b;
13 lfname = NULL;
14 elist = NO;
15 external = YES;
16 errflag = a->cerr;
17 lunit = a->cunit;
3bbbaca0 18 if(not_legal(lunit)) err(errflag,F_ERUNIT,"close");
e798709f 19 if(lunit==STDERR && (!a->csta || *a->csta != FROM_OPEN))
3bbbaca0 20 err(errflag,F_ERUNIT,"can't close stderr");
e798709f 21 b= &units[lunit];
3bbbaca0 22 if(!b->ufd) err(errflag,F_ERNOPEN,"close");
e798709f
DW
23 if(a->csta)
24 switch(lcase(*a->csta))
25 {
26 delete:
27 case 'd':
28 fclose(b->ufd);
29 if(b->ufnm) unlink(b->ufnm); /*SYSDEP*/
30 break;
31 default:
32 keep:
33 case 'k':
34 if(b->uwrt) t_runc(b,errflag);
35 fclose(b->ufd);
36 break;
37 }
38 else if(b->uscrtch) goto delete;
39 else goto keep;
40 if(b->ufnm) free(b->ufnm);
41 b->ufnm=NULL;
42 b->ufd=NULL;
43 return(OK);
44}
45
46f_exit()
47{
48 ftnint lu, dofirst = YES;
49 cllist xx;
50 xx.cerr=1;
51 xx.csta=NULL;
52 for(lu=STDOUT; (dofirst || lu!=STDOUT); lu = ++lu % MXUNIT)
53 {
54 xx.cunit=lu;
55 f_clos(&xx);
56 dofirst = NO;
57 }
58}
59
60ftnint
61flush_(u) ftnint *u;
62{
63 FILE *F = units[*u].ufd;
64 if(F)
65 return(fflush(F));
66 else
3bbbaca0 67 return(F_ERNOPEN);
e798709f 68}