mariadb/storage/bdb/os_win32/os_errno.c
2005-12-05 10:27:46 -08:00

136 lines
2.3 KiB
C

/*-
* See the file LICENSE for redistribution information.
*
* Copyright (c) 1999-2005
* Sleepycat Software. All rights reserved.
*
* $Id: os_errno.c,v 12.2 2005/06/16 20:23:28 bostic Exp $
*/
#include "db_config.h"
#include "db_int.h"
/*
* __os_get_errno_ret_zero --
* Return the value of errno, even if it's zero.
*/
int
__os_get_errno_ret_zero()
{
/* This routine must be able to return the same value repeatedly. */
return (errno);
}
/*
* __os_get_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.
*/
int
__os_get_errno()
{
DWORD last_error;
int ret;
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;
break;
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:
case ERROR_ALREADY_EXISTS:
ret = EEXIST;
break;
case ERROR_NOT_SAME_DEVICE:
ret = EXDEV;
break;
case ERROR_WRITE_PROTECT:
ret = EACCES;
break;
case ERROR_LOCK_FAILED:
case ERROR_NOT_READY:
case ERROR_LOCK_VIOLATION:
case ERROR_SHARING_VIOLATION:
ret = EBUSY;
break;
case ERROR_RETRY:
ret = EINTR;
break;
case 0:
ret = EFAULT;
break;
default:
ret = EIO; /* Generic error. */
break;
}
return (ret);
}
/*
* __os_set_errno --
* Set the value of errno.
*/
void
__os_set_errno(evalue)
int evalue;
{
errno = evalue;
}