Add GNU LGPL headers to all .c .C and .h files
[oweals/cde.git] / cde / lib / tt / mini_isam / isclose.c
1 /*
2  * CDE - Common Desktop Environment
3  *
4  * Copyright (c) 1993-2012, The Open Group. All rights reserved.
5  *
6  * These libraries and programs are free software; you can
7  * redistribute them and/or modify them under the terms of the GNU
8  * Lesser General Public License as published by the Free Software
9  * Foundation; either version 2 of the License, or (at your option)
10  * any later version.
11  *
12  * These libraries and programs are distributed in the hope that
13  * they will be useful, but WITHOUT ANY WARRANTY; without even the
14  * implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR
15  * PURPOSE. See the GNU Lesser General Public License for more
16  * details.
17  *
18  * You should have received a copy of the GNU Lesser General Public
19  * License along with these librararies and programs; if not, write
20  * to the Free Software Foundation, Inc., 51 Franklin Street, Fifth
21  * Floor, Boston, MA 02110-1301 USA
22  */
23 /*%%  (c) Copyright 1993, 1994 Hewlett-Packard Company                   */
24 /*%%  (c) Copyright 1993, 1994 International Business Machines Corp.     */
25 /*%%  (c) Copyright 1993, 1994 Sun Microsystems, Inc.                    */
26 /*%%  (c) Copyright 1993, 1994 Novell, Inc.                              */
27 /*%%  $XConsortium: isclose.c /main/3 1995/10/23 11:36:50 rswiston $                                                     */
28 #ifndef lint
29 static char sccsid[] = "@(#)isclose.c 1.8 89/07/17 Copyr 1988 Sun Micro";
30 #endif
31 /*
32  * Copyright (c) 1988 by Sun Microsystems, Inc.
33  */
34
35 /*
36  * isclose.c
37  *
38  * Description:
39  *      Close an ISAM file
40  */
41
42 #include "isam_impl.h"
43 #include <sys/time.h>
44
45 /*
46  * isclose(isfd)
47  *
48  * Isclose() closes the ISAM file associated with the file descriptor isfd.
49  * There may be other ISAM file descriptors in use which are associated 
50  * with the same ISAM file; are not effected by isclose().
51  *
52  * Isclose() returns -1 if an errors was detected, or 0 if the file was closed
53  * successfully.
54  *
55  * Errors:
56  *      ENOTOPEN isfd is not ISAM file descriptor of an open ISAM file.
57  */
58
59 int
60 isclose(isfd)
61     int         isfd;
62 {
63     Fab         *fab;
64     Fcb         *fcb;
65
66     if ((fab = _isfd_find(isfd)) == NULL) {
67         _setiserrno2(ENOTOPEN, '9', '0');
68         return (ISERROR);
69     }
70
71     _isam_entryhook();
72
73     /*
74      * Get FCB corresponding to the isfhandle handle.
75      */
76     if ((fcb = _openfcb(&fab->isfhandle, &fab->errcode)) == NULL) {
77         _isam_exithook();
78         return (ISERROR);
79     }
80
81     /*
82      * Delete FCB and remove it from FCB cache. Close UNIX fds.
83      *
84      * This is desirable when ISAM files are removed from other processes,
85      * or simply by 'rm file.*'. 
86      */
87     (void) _watchfd_decr(_isfcb_nfds(fcb));
88     _isfcb_close(fcb);
89     _mngfcb_delete(&fab->isfhandle);
90
91     _isam_exithook();
92
93     _fab_destroy(fab);                       /* Deallocate Fab object */
94     _isfd_delete(isfd);
95     
96     return (ISOK);
97 }