// Copyright (c) 2011 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. #include "net/base/net_errors.h" #include <errno.h> #include <stdlib.h> #include <string> #include <unistd.h> #include "base/logging.h" #include "base/strings/stringprintf.h" namespace net { Error MapSystemError(int os_error) { if (os_error != 0) DVLOG(2) << "Error " << os_error; // There are numerous posix error codes, but these are the ones we thus far // find interesting. switch (os_error) { case EAGAIN: #if EWOULDBLOCK != EAGAIN case EWOULDBLOCK: #endif return ERR_IO_PENDING; case EACCES: return ERR_ACCESS_DENIED; case ENETDOWN: return ERR_INTERNET_DISCONNECTED; case ETIMEDOUT: return ERR_TIMED_OUT; case ECONNRESET: case ENETRESET: // Related to keep-alive. case EPIPE: return ERR_CONNECTION_RESET; case ECONNABORTED: return ERR_CONNECTION_ABORTED; case ECONNREFUSED: return ERR_CONNECTION_REFUSED; case EHOSTUNREACH: case EHOSTDOWN: case ENETUNREACH: case EAFNOSUPPORT: return ERR_ADDRESS_UNREACHABLE; case EADDRNOTAVAIL: return ERR_ADDRESS_INVALID; case EMSGSIZE: return ERR_MSG_TOO_BIG; case ENOTCONN: return ERR_SOCKET_NOT_CONNECTED; case EISCONN: return ERR_SOCKET_IS_CONNECTED; case EINVAL: return ERR_INVALID_ARGUMENT; case EADDRINUSE: return ERR_ADDRESS_IN_USE; case E2BIG: // Argument list too long. return ERR_INVALID_ARGUMENT; case EBADF: // Bad file descriptor. return ERR_INVALID_HANDLE; case EBUSY: // Device or resource busy. return ERR_INSUFFICIENT_RESOURCES; case ECANCELED: // Operation canceled. return ERR_ABORTED; case EDEADLK: // Resource deadlock avoided. return ERR_INSUFFICIENT_RESOURCES; case EDQUOT: // Disk quota exceeded. return ERR_FILE_NO_SPACE; case EEXIST: // File exists. return ERR_FILE_EXISTS; case EFAULT: // Bad address. return ERR_INVALID_ARGUMENT; case EFBIG: // File too large. return ERR_FILE_TOO_BIG; case EISDIR: // Operation not allowed for a directory. return ERR_ACCESS_DENIED; case ENAMETOOLONG: // Filename too long. return ERR_FILE_PATH_TOO_LONG; case ENFILE: // Too many open files in system. return ERR_INSUFFICIENT_RESOURCES; case ENOBUFS: // No buffer space available. return ERR_OUT_OF_MEMORY; case ENODEV: // No such device. return ERR_INVALID_ARGUMENT; case ENOENT: // No such file or directory. return ERR_FILE_NOT_FOUND; case ENOLCK: // No locks available. return ERR_INSUFFICIENT_RESOURCES; case ENOMEM: // Not enough space. return ERR_OUT_OF_MEMORY; case ENOSPC: // No space left on device. return ERR_FILE_NO_SPACE; case ENOSYS: // Function not implemented. return ERR_NOT_IMPLEMENTED; case ENOTDIR: // Not a directory. return ERR_FILE_NOT_FOUND; case ENOTSUP: // Operation not supported. return ERR_NOT_IMPLEMENTED; case EPERM: // Operation not permitted. return ERR_ACCESS_DENIED; case EROFS: // Read-only file system. return ERR_ACCESS_DENIED; case ETXTBSY: // Text file busy. return ERR_ACCESS_DENIED; case EUSERS: // Too many users. return ERR_INSUFFICIENT_RESOURCES; case EMFILE: // Too many open files. return ERR_INSUFFICIENT_RESOURCES; case 0: return OK; default: LOG(WARNING) << "Unknown error " << os_error << " mapped to net::ERR_FAILED"; return ERR_FAILED; } } } // namespace net