blob: 8324826b6f9805b4f39915a5cb3cc0bbd9d7f512 (
plain)
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
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
|
/*-
* See the file LICENSE for redistribution information.
*
* Copyright (c) 1999, 2000
* Sleepycat Software. All rights reserved.
*/
#include "db_config.h"
#ifndef lint
static const char revid[] = "$Id: os_errno.c,v 11.5 2000/11/30 00:58:43 ubell Exp $";
#endif /* not lint */
#include "db_int.h"
/*
* __os_get_errno --
* Return the value of errno.
*/
int
__os_get_errno()
{
/* This routine must be able to return the same value repeatedly. */
return (errno);
}
/*
* __os_set_errno --
* Set the value of errno.
*/
void
__os_set_errno(evalue)
int evalue;
{
errno = evalue;
}
/*
* __os_win32_errno --
* Return the last Windows error as an errno.
* We give generic error returns:
*
* EFAULT means Win* call failed,
* and GetLastError provided no extra info.
*
* EIO means error on Win* call.
* and we were unable to provide a meaningful errno for this Windows
* error. More information is only available by setting a breakpoint
* here.
*
* PUBLIC: #if defined(DB_WIN32)
* PUBLIC: int __os_win32_errno __P((void));
* PUBLIC: #endif
*/
int
__os_win32_errno(void)
{
DWORD last_error;
int ret;
/*
* It's possible that errno was set after the error.
* The caller must take care to set it to 0 before
* any system operation.
*/
if (__os_get_errno() != 0)
return (__os_get_errno());
last_error = GetLastError();
/*
* Take our best guess at translating some of the Windows error
* codes. We really care about only a few of these.
*/
switch (last_error) {
case ERROR_FILE_NOT_FOUND:
case ERROR_INVALID_DRIVE:
case ERROR_PATH_NOT_FOUND:
ret = ENOENT;
break;
case ERROR_NO_MORE_FILES:
case ERROR_TOO_MANY_OPEN_FILES:
ret = EMFILE;
break;
case ERROR_ACCESS_DENIED:
ret = EPERM;
break;
case ERROR_INVALID_HANDLE:
ret = EBADF;
break;
case ERROR_NOT_ENOUGH_MEMORY:
ret = ENOMEM;
break;
case ERROR_DISK_FULL:
ret = ENOSPC;
case ERROR_ARENA_TRASHED:
case ERROR_BAD_COMMAND:
case ERROR_BAD_ENVIRONMENT:
case ERROR_BAD_FORMAT:
case ERROR_GEN_FAILURE:
case ERROR_INVALID_ACCESS:
case ERROR_INVALID_BLOCK:
case ERROR_INVALID_DATA:
case ERROR_READ_FAULT:
case ERROR_WRITE_FAULT:
ret = EFAULT;
break;
case ERROR_FILE_EXISTS:
ret = EEXIST;
break;
case ERROR_NOT_SAME_DEVICE:
ret = EXDEV;
break;
case ERROR_WRITE_PROTECT:
ret = EACCES;
break;
case ERROR_NOT_READY:
ret = EBUSY;
break;
case ERROR_LOCK_VIOLATION:
case ERROR_SHARING_VIOLATION:
ret = EBUSY;
break;
case 0:
ret = EFAULT;
break;
default:
ret = EIO; /* Generic error. */
break;
}
return (ret);
}
|