[io-layer] Extract file (#4255)
[mono.git] / mono / io-layer / error.c
index 7b41f3568bb3ce59e6d5664ba0e3a7e9e52b30d6..38a9141d2e1caad4f1bd43420d4643ca072e802d 100644 (file)
 #include <errno.h>
 
 #include "mono/io-layer/wapi.h"
+#include "mono/utils/mono-lazy-init.h"
 
 static pthread_key_t error_key;
-static mono_once_t error_key_once=MONO_ONCE_INIT;
+static mono_lazy_init_t error_key_once = MONO_LAZY_INIT_STATUS_NOT_INITIALIZED;
 
 static void error_init(void)
 {
@@ -38,8 +39,8 @@ guint32 GetLastError(void)
 {
        guint32 err;
        void *errptr;
-       
-       mono_once(&error_key_once, error_init);
+
+       mono_lazy_initialize(&error_key_once, error_init);
        errptr=pthread_getspecific(error_key);
        err=GPOINTER_TO_UINT(errptr);
        
@@ -57,84 +58,11 @@ void SetLastError(guint32 code)
        int ret;
        
        /* Set the thread-local error code */
-       mono_once(&error_key_once, error_init);
+       mono_lazy_initialize(&error_key_once, error_init);
        ret = pthread_setspecific(error_key, GUINT_TO_POINTER(code));
        g_assert (ret == 0);
 }
 
-guint32
-errno_to_WSA (guint32 code, const gchar *function_name)
-{
-       gint result = -1;
-       char *sys_error;
-       gchar *msg;
-
-       switch (code) {
-       case 0: result = ERROR_SUCCESS; break;
-       case EACCES: result = WSAEACCES; break;
-       case EADDRINUSE: result = WSAEADDRINUSE; break;
-       case EAFNOSUPPORT: result = WSAEAFNOSUPPORT; break;
-#if EAGAIN != EWOULDBLOCK
-       case EAGAIN: result = WSAEWOULDBLOCK; break;
-#endif
-       case EALREADY: result = WSAEALREADY; break;
-       case EBADF: result = WSAENOTSOCK; break;
-       case ECONNABORTED: result = WSAENETDOWN; break;
-       case ECONNREFUSED: result = WSAECONNREFUSED; break;
-       case ECONNRESET: result = WSAECONNRESET; break;
-       case EFAULT: result = WSAEFAULT; break;
-       case EHOSTUNREACH: result = WSAEHOSTUNREACH; break;
-       case EINPROGRESS: result = WSAEINPROGRESS; break;
-       case EINTR: result = WSAEINTR; break;
-       case EINVAL: result = WSAEINVAL; break;
-       /*FIXME: case EIO: result = WSAE????; break; */
-       case EISCONN: result = WSAEISCONN; break;
-       /* FIXME: case ELOOP: result = WSA????; break; */
-       case EMFILE: result = WSAEMFILE; break;
-       case EMSGSIZE: result = WSAEMSGSIZE; break;
-       /* FIXME: case ENAMETOOLONG: result = WSAEACCES; break; */
-       case ENETUNREACH: result = WSAENETUNREACH; break;
-       case ENOBUFS: result = WSAENOBUFS; break; /* not documented */
-       /* case ENOENT: result = WSAE????; break; */
-       case ENOMEM: result = WSAENOBUFS; break;
-       case ENOPROTOOPT: result = WSAENOPROTOOPT; break;
-#ifdef ENOSR
-       case ENOSR: result = WSAENETDOWN; break;
-#endif
-       case ENOTCONN: result = WSAENOTCONN; break;
-       /*FIXME: case ENOTDIR: result = WSAE????; break; */
-       case ENOTSOCK: result = WSAENOTSOCK; break;
-       case ENOTTY: result = WSAENOTSOCK; break;
-       case EOPNOTSUPP: result = WSAEOPNOTSUPP; break;
-       case EPERM: result = WSAEACCES; break;
-       case EPIPE: result = WSAESHUTDOWN; break;
-       case EPROTONOSUPPORT: result = WSAEPROTONOSUPPORT; break;
-#if ERESTARTSYS
-       case ERESTARTSYS: result = WSAENETDOWN; break;
-#endif
-       /*FIXME: case EROFS: result = WSAE????; break; */
-       case ESOCKTNOSUPPORT: result = WSAESOCKTNOSUPPORT; break;
-       case ETIMEDOUT: result = WSAENETDOWN; break;
-       case EWOULDBLOCK: result = WSAEWOULDBLOCK; break;
-       case EADDRNOTAVAIL: result = WSAEADDRNOTAVAIL; break;
-       /* This might happen with unix sockets */
-       case ENOENT: result = WSAECONNREFUSED; break;
-       default:
-               sys_error = strerror (code);
-               msg = g_locale_to_utf8 (sys_error, strlen (sys_error), NULL, NULL, NULL);
-               if (function_name == NULL)
-                       function_name = __func__;
-
-               g_warning ("%s: Need to translate %d [%s] into winsock error",
-                          function_name, code, msg);
-
-               g_free (msg);
-               result = WSASYSCALLFAILURE;
-       }
-
-       return result;
-}
-
 gint
 _wapi_get_win32_file_error (gint err)
 {
@@ -190,9 +118,11 @@ _wapi_get_win32_file_error (gint err)
                ret = ERROR_FILENAME_EXCED_RANGE;
                break;
        
+#ifdef EINPROGRESS
        case EINPROGRESS:
                ret = ERROR_IO_PENDING;
                break;
+#endif
        
        case ENOSYS:
                ret = ERROR_NOT_SUPPORTED;