Blame gio/gioerror.c

Packit 84794d
/* GIO - GLib Input, Output and Streaming Library
Packit 84794d
 * 
Packit 84794d
 * Copyright (C) 2006-2007 Red Hat, Inc.
Packit 84794d
 *
Packit 84794d
 * This library is free software; you can redistribute it and/or
Packit 84794d
 * modify it under the terms of the GNU Lesser General Public
Packit 84794d
 * License as published by the Free Software Foundation; either
Packit 84794d
 * version 2.1 of the License, or (at your option) any later version.
Packit 84794d
 *
Packit 84794d
 * This library is distributed in the hope that it will be useful,
Packit 84794d
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit 84794d
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
Packit 84794d
 * Lesser General Public License for more details.
Packit 84794d
 *
Packit 84794d
 * You should have received a copy of the GNU Lesser General
Packit 84794d
 * Public License along with this library; if not, see <http://www.gnu.org/licenses/>.
Packit 84794d
 *
Packit 84794d
 * Author: Alexander Larsson <alexl@redhat.com>
Packit 84794d
 */
Packit 84794d
Packit 84794d
#include "config.h"
Packit 84794d
#include <errno.h>
Packit 84794d
#include "gioerror.h"
Packit 84794d
Packit 84794d
#ifdef G_OS_WIN32
Packit 84794d
#include <winsock2.h>
Packit 84794d
#endif
Packit 84794d
Packit 84794d
/**
Packit 84794d
 * SECTION:gioerror
Packit 84794d
 * @short_description: Error helper functions
Packit 84794d
 * @include: gio/gio.h
Packit 84794d
 *
Packit 84794d
 * Contains helper functions for reporting errors to the user.
Packit 84794d
 **/
Packit 84794d
Packit 84794d
/**
Packit 84794d
 * g_io_error_quark:
Packit 84794d
 *
Packit 84794d
 * Gets the GIO Error Quark.
Packit 84794d
 *
Packit 84794d
 * Returns: a #GQuark.
Packit 84794d
 **/
Packit 84794d
G_DEFINE_QUARK (g-io-error-quark, g_io_error)
Packit 84794d
Packit 84794d
/**
Packit 84794d
 * g_io_error_from_errno:
Packit 84794d
 * @err_no: Error number as defined in errno.h.
Packit 84794d
 *
Packit 84794d
 * Converts errno.h error codes into GIO error codes. The fallback
Packit 84794d
 * value %G_IO_ERROR_FAILED is returned for error codes not currently
Packit 84794d
 * handled (but note that future GLib releases may return a more
Packit 84794d
 * specific value instead).
Packit 84794d
 *
Packit 84794d
 * As %errno is global and may be modified by intermediate function
Packit 84794d
 * calls, you should save its value as soon as the call which sets it
Packit 84794d
 * returns:
Packit 84794d
 * |[
Packit 84794d
 *   int saved_errno;
Packit 84794d
 *
Packit 84794d
 *   ret = read (blah);
Packit 84794d
 *   saved_errno = errno;
Packit 84794d
 *
Packit 84794d
 *   g_io_error_from_errno (saved_errno);
Packit 84794d
 * ]|
Packit 84794d
 *
Packit 84794d
 * Returns: #GIOErrorEnum value for the given errno.h error number.
Packit 84794d
 **/
Packit 84794d
GIOErrorEnum
Packit 84794d
g_io_error_from_errno (gint err_no)
Packit 84794d
{
Packit 84794d
  switch (err_no)
Packit 84794d
    {
Packit 84794d
#ifdef EEXIST
Packit 84794d
    case EEXIST:
Packit 84794d
      return G_IO_ERROR_EXISTS;
Packit 84794d
      break;
Packit 84794d
#endif
Packit 84794d
Packit 84794d
#ifdef EISDIR
Packit 84794d
    case EISDIR:
Packit 84794d
      return G_IO_ERROR_IS_DIRECTORY;
Packit 84794d
      break;
Packit 84794d
#endif
Packit 84794d
Packit 84794d
#ifdef EACCES
Packit 84794d
    case EACCES:
Packit 84794d
      return G_IO_ERROR_PERMISSION_DENIED;
Packit 84794d
      break;
Packit 84794d
#endif
Packit 84794d
Packit 84794d
#ifdef ENAMETOOLONG
Packit 84794d
    case ENAMETOOLONG:
Packit 84794d
      return G_IO_ERROR_FILENAME_TOO_LONG;
Packit 84794d
      break;
Packit 84794d
#endif
Packit 84794d
Packit 84794d
#ifdef ENOENT
Packit 84794d
    case ENOENT:
Packit 84794d
      return G_IO_ERROR_NOT_FOUND;
Packit 84794d
      break;
Packit 84794d
#endif
Packit 84794d
Packit 84794d
#ifdef ENOTDIR
Packit 84794d
    case ENOTDIR:
Packit 84794d
      return G_IO_ERROR_NOT_DIRECTORY;
Packit 84794d
      break;
Packit 84794d
#endif
Packit 84794d
Packit 84794d
#ifdef EROFS
Packit 84794d
    case EROFS:
Packit 84794d
      return G_IO_ERROR_READ_ONLY;
Packit 84794d
      break;
Packit 84794d
#endif
Packit 84794d
Packit 84794d
#ifdef ELOOP
Packit 84794d
    case ELOOP:
Packit 84794d
      return G_IO_ERROR_TOO_MANY_LINKS;
Packit 84794d
      break;
Packit 84794d
#endif
Packit 84794d
Packit 84794d
#ifdef ENOSPC
Packit 84794d
    case ENOSPC:
Packit 84794d
      return G_IO_ERROR_NO_SPACE;
Packit 84794d
      break;
Packit 84794d
#endif
Packit 84794d
Packit 84794d
#ifdef ENOMEM
Packit 84794d
    case ENOMEM:
Packit 84794d
      return G_IO_ERROR_NO_SPACE;
Packit 84794d
      break;
Packit 84794d
#endif
Packit 84794d
      
Packit 84794d
#ifdef EINVAL
Packit 84794d
    case EINVAL:
Packit 84794d
      return G_IO_ERROR_INVALID_ARGUMENT;
Packit 84794d
      break;
Packit 84794d
#endif
Packit 84794d
Packit 84794d
#ifdef EPERM
Packit 84794d
    case EPERM:
Packit 84794d
      return G_IO_ERROR_PERMISSION_DENIED;
Packit 84794d
      break;
Packit 84794d
#endif
Packit 84794d
Packit 84794d
#ifdef ECANCELED
Packit 84794d
    case ECANCELED:
Packit 84794d
      return G_IO_ERROR_CANCELLED;
Packit 84794d
      break;
Packit 84794d
#endif
Packit 84794d
Packit 84794d
    /* ENOTEMPTY == EEXIST on AIX for backward compatibility reasons */
Packit 84794d
#if defined (ENOTEMPTY) && (!defined (EEXIST) || (ENOTEMPTY != EEXIST))
Packit 84794d
    case ENOTEMPTY:
Packit 84794d
      return G_IO_ERROR_NOT_EMPTY;
Packit 84794d
      break;
Packit 84794d
#endif
Packit 84794d
Packit 84794d
#ifdef ENOTSUP
Packit 84794d
    case ENOTSUP:
Packit 84794d
      return G_IO_ERROR_NOT_SUPPORTED;
Packit 84794d
      break;
Packit 84794d
#endif
Packit 84794d
Packit 84794d
    /* EOPNOTSUPP == ENOTSUP on Linux, but POSIX considers them distinct */
Packit 84794d
#if defined (EOPNOTSUPP) && (!defined (ENOTSUP) || (EOPNOTSUPP != ENOTSUP))
Packit 84794d
    case EOPNOTSUPP:
Packit 84794d
      return G_IO_ERROR_NOT_SUPPORTED;
Packit 84794d
      break;
Packit 84794d
#endif
Packit 84794d
Packit 84794d
#ifdef EPROTONOSUPPORT
Packit 84794d
    case EPROTONOSUPPORT:
Packit 84794d
      return G_IO_ERROR_NOT_SUPPORTED;
Packit 84794d
      break;
Packit 84794d
#endif
Packit 84794d
Packit 84794d
#ifdef ESOCKTNOSUPPORT
Packit 84794d
    case ESOCKTNOSUPPORT:
Packit 84794d
      return G_IO_ERROR_NOT_SUPPORTED;
Packit 84794d
      break;
Packit 84794d
#endif
Packit 84794d
Packit 84794d
#ifdef EPFNOSUPPORT
Packit 84794d
    case EPFNOSUPPORT:
Packit 84794d
      return G_IO_ERROR_NOT_SUPPORTED;
Packit 84794d
      break;
Packit 84794d
#endif
Packit 84794d
Packit 84794d
#ifdef EAFNOSUPPORT
Packit 84794d
    case EAFNOSUPPORT:
Packit 84794d
      return G_IO_ERROR_NOT_SUPPORTED;
Packit 84794d
      break;
Packit 84794d
#endif
Packit 84794d
Packit 84794d
#ifdef ETIMEDOUT
Packit 84794d
    case ETIMEDOUT:
Packit 84794d
      return G_IO_ERROR_TIMED_OUT;
Packit 84794d
      break;
Packit 84794d
#endif
Packit 84794d
Packit 84794d
#ifdef EBUSY
Packit 84794d
    case EBUSY:
Packit 84794d
      return G_IO_ERROR_BUSY;
Packit 84794d
      break;
Packit 84794d
#endif
Packit 84794d
Packit 84794d
#ifdef EWOULDBLOCK
Packit 84794d
    case EWOULDBLOCK:
Packit 84794d
      return G_IO_ERROR_WOULD_BLOCK;
Packit 84794d
      break;
Packit 84794d
#endif
Packit 84794d
Packit 84794d
    /* EWOULDBLOCK == EAGAIN on most systems, but POSIX considers them distinct */
Packit 84794d
#if defined (EAGAIN) && (!defined (EWOULDBLOCK) || (EWOULDBLOCK != EAGAIN))
Packit 84794d
    case EAGAIN:
Packit 84794d
      return G_IO_ERROR_WOULD_BLOCK;
Packit 84794d
      break;
Packit 84794d
#endif
Packit 84794d
Packit 84794d
#ifdef EMFILE
Packit 84794d
    case EMFILE:
Packit 84794d
      return G_IO_ERROR_TOO_MANY_OPEN_FILES;
Packit 84794d
      break;
Packit 84794d
#endif
Packit 84794d
Packit 84794d
#ifdef EADDRINUSE
Packit 84794d
    case EADDRINUSE:
Packit 84794d
      return G_IO_ERROR_ADDRESS_IN_USE;
Packit 84794d
      break;
Packit 84794d
#endif
Packit 84794d
Packit 84794d
#ifdef EHOSTUNREACH
Packit 84794d
    case EHOSTUNREACH:
Packit 84794d
      return G_IO_ERROR_HOST_UNREACHABLE;
Packit 84794d
      break;
Packit 84794d
#endif
Packit 84794d
Packit 84794d
#ifdef ENETUNREACH
Packit 84794d
    case ENETUNREACH:
Packit 84794d
      return G_IO_ERROR_NETWORK_UNREACHABLE;
Packit 84794d
      break;
Packit 84794d
#endif
Packit 84794d
Packit 84794d
#ifdef ECONNREFUSED
Packit 84794d
    case ECONNREFUSED:
Packit 84794d
      return G_IO_ERROR_CONNECTION_REFUSED;
Packit 84794d
      break;
Packit 84794d
#endif
Packit 84794d
Packit 84794d
#ifdef EPIPE
Packit 84794d
    case EPIPE:
Packit 84794d
      return G_IO_ERROR_BROKEN_PIPE;
Packit 84794d
      break;
Packit 84794d
#endif
Packit 84794d
Packit 84794d
#ifdef ECONNRESET
Packit 84794d
    case ECONNRESET:
Packit 84794d
      return G_IO_ERROR_CONNECTION_CLOSED;
Packit 84794d
      break;
Packit 84794d
#endif
Packit 84794d
Packit 84794d
#ifdef ENOTCONN
Packit 84794d
    case ENOTCONN:
Packit 84794d
      return G_IO_ERROR_NOT_CONNECTED;
Packit 84794d
      break;
Packit 84794d
#endif
Packit 84794d
Packit 84794d
#ifdef EMSGSIZE
Packit 84794d
    case EMSGSIZE:
Packit 84794d
      return G_IO_ERROR_MESSAGE_TOO_LARGE;
Packit 84794d
      break;
Packit 84794d
#endif
Packit 84794d
Packit 84794d
    default:
Packit 84794d
      return G_IO_ERROR_FAILED;
Packit 84794d
      break;
Packit 84794d
    }
Packit 84794d
}
Packit 84794d
Packit 84794d
#ifdef G_OS_WIN32
Packit 84794d
Packit 84794d
/**
Packit 84794d
 * g_io_error_from_win32_error:
Packit 84794d
 * @error_code: Windows error number.
Packit 84794d
 *
Packit 84794d
 * Converts some common error codes (as returned from GetLastError()
Packit 84794d
 * or WSAGetLastError()) into GIO error codes. The fallback value
Packit 84794d
 * %G_IO_ERROR_FAILED is returned for error codes not currently
Packit 84794d
 * handled (but note that future GLib releases may return a more
Packit 84794d
 * specific value instead).
Packit 84794d
 *
Packit 84794d
 * You can use g_win32_error_message() to get a localized string
Packit 84794d
 * corresponding to @error_code. (But note that unlike g_strerror(),
Packit 84794d
 * g_win32_error_message() returns a string that must be freed.)
Packit 84794d
 *
Packit 84794d
 * Returns: #GIOErrorEnum value for the given error number.
Packit 84794d
 *
Packit 84794d
 * Since: 2.26
Packit 84794d
 **/
Packit 84794d
GIOErrorEnum
Packit 84794d
g_io_error_from_win32_error (gint error_code)
Packit 84794d
{
Packit 84794d
  /* Note: Winsock errors are a subset of Win32 error codes as a
Packit 84794d
   * whole. (The fact that the Winsock API makes them look like they
Packit 84794d
   * aren't is just because the API predates Win32.)
Packit 84794d
   */
Packit 84794d
Packit 84794d
  switch (error_code)
Packit 84794d
    {
Packit 84794d
    case WSAEADDRINUSE:
Packit 84794d
      return G_IO_ERROR_ADDRESS_IN_USE;
Packit 84794d
Packit 84794d
    case WSAEWOULDBLOCK:
Packit 84794d
      return G_IO_ERROR_WOULD_BLOCK;
Packit 84794d
Packit 84794d
    case WSAEACCES:
Packit 84794d
      return G_IO_ERROR_PERMISSION_DENIED;
Packit 84794d
Packit 84794d
    case WSA_INVALID_HANDLE:
Packit 84794d
    case WSA_INVALID_PARAMETER:
Packit 84794d
    case WSAEINVAL:
Packit 84794d
    case WSAEBADF:
Packit 84794d
    case WSAENOTSOCK:
Packit 84794d
      return G_IO_ERROR_INVALID_ARGUMENT;
Packit 84794d
Packit 84794d
    case WSAEPROTONOSUPPORT:
Packit 84794d
      return G_IO_ERROR_NOT_SUPPORTED;
Packit 84794d
Packit 84794d
    case WSAECANCELLED:
Packit 84794d
      return G_IO_ERROR_CANCELLED;
Packit 84794d
Packit 84794d
    case WSAESOCKTNOSUPPORT:
Packit 84794d
    case WSAEOPNOTSUPP:
Packit 84794d
    case WSAEPFNOSUPPORT:
Packit 84794d
    case WSAEAFNOSUPPORT:
Packit 84794d
      return G_IO_ERROR_NOT_SUPPORTED;
Packit 84794d
Packit 84794d
    case WSAECONNRESET:
Packit 84794d
    case WSAESHUTDOWN:
Packit 84794d
      return G_IO_ERROR_CONNECTION_CLOSED;
Packit 84794d
Packit 84794d
    case WSAEHOSTUNREACH:
Packit 84794d
      return G_IO_ERROR_HOST_UNREACHABLE;
Packit 84794d
Packit 84794d
    case WSAENETUNREACH:
Packit 84794d
      return G_IO_ERROR_NETWORK_UNREACHABLE;
Packit 84794d
Packit 84794d
    case WSAECONNREFUSED:
Packit 84794d
      return G_IO_ERROR_CONNECTION_REFUSED;
Packit 84794d
Packit 84794d
    case WSAETIMEDOUT:
Packit 84794d
      return G_IO_ERROR_TIMED_OUT;
Packit 84794d
Packit 84794d
    case WSAENOTCONN:
Packit 84794d
    case ERROR_PIPE_LISTENING:
Packit 84794d
      return G_IO_ERROR_NOT_CONNECTED;
Packit 84794d
Packit 84794d
    case WSAEMSGSIZE:
Packit 84794d
      return G_IO_ERROR_MESSAGE_TOO_LARGE;
Packit 84794d
Packit 84794d
    default:
Packit 84794d
      return G_IO_ERROR_FAILED;
Packit 84794d
    }
Packit 84794d
}
Packit 84794d
Packit 84794d
#endif