1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
|
/*-
* See the file LICENSE for redistribution information.
*
* Copyright (c) 1997-2006
* Oracle Corporation. All rights reserved.
*
* $Id: os_unlink.c,v 12.8 2006/08/24 14:46:18 bostic Exp $
*/
#include "db_config.h"
#include "db_int.h"
/*
* __os_region_unlink --
* Remove a shared memory object file.
*
* PUBLIC: int __os_region_unlink __P((DB_ENV *, const char *));
*/
int
__os_region_unlink(dbenv, path)
DB_ENV *dbenv;
const char *path;
{
#ifdef HAVE_QNX
int ret;
char *newname;
if ((ret = __os_shmname(dbenv, path, &newname)) != 0)
goto err;
if ((ret = shm_unlink(newname)) != 0) {
ret = __os_get_syserr();
if (__os_posix_err(ret) != ENOENT)
__db_syserr(dbenv, ret, "shm_unlink: %s", newname);
}
err:
if (newname != NULL)
__os_free(dbenv, newname);
return (ret);
#else
if (F_ISSET(dbenv, DB_ENV_OVERWRITE))
(void)__db_file_multi_write(dbenv, path);
return (__os_unlink(dbenv, path));
#endif
}
/*
* __os_unlink --
* Remove a file.
*
* PUBLIC: int __os_unlink __P((DB_ENV *, const char *));
*/
int
__os_unlink(dbenv, path)
DB_ENV *dbenv;
const char *path;
{
int ret, t_ret;
if (DB_GLOBAL(j_unlink) != NULL)
ret = DB_GLOBAL(j_unlink)(path);
else
#ifdef HAVE_VXWORKS
RETRY_CHK((unlink((char *)path)), ret);
#else
RETRY_CHK((unlink(path)), ret);
#endif
/*
* !!!
* The results of unlink are file system driver specific on VxWorks.
* In the case of removing a file that did not exist, some, at least,
* return an error, but with an errno of 0, not ENOENT. We do not
* have to test for the explicitly, the RETRY_CHK macro resets "ret"
* to be the errno, and so we'll just slide right on through.
*
* XXX
* We shouldn't be testing for an errno of ENOENT here, but ENOENT
* signals that a file is missing, and we attempt to unlink things
* (such as v. 2.x environment regions, in DB_ENV->remove) that we
* are expecting not to be there. Reporting errors in these cases
* is annoying.
*/
if (ret != 0) {
t_ret = __os_posix_err(ret);
if (t_ret != ENOENT)
__db_syserr(dbenv, ret, "unlink: %s", path);
ret = t_ret;
}
return (ret);
}
|