Blame xpcom/io/nsLocalFile.h

Packit f0b94e
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
Packit f0b94e
/* vim: set ts=8 sts=2 et sw=2 tw=80: */
Packit f0b94e
/* This Source Code Form is subject to the terms of the Mozilla Public
Packit f0b94e
 * License, v. 2.0. If a copy of the MPL was not distributed with this
Packit f0b94e
 * file, You can obtain one at http://mozilla.org/MPL/2.0/. */
Packit f0b94e
Packit f0b94e
#ifndef _NS_LOCAL_FILE_H_
Packit f0b94e
#define _NS_LOCAL_FILE_H_
Packit f0b94e
Packit f0b94e
#include "nscore.h"
Packit f0b94e
Packit f0b94e
#define NS_LOCAL_FILE_CID                            \
Packit f0b94e
  {                                                  \
Packit f0b94e
    0x2e23e220, 0x60be, 0x11d3, {                    \
Packit f0b94e
      0x8c, 0x4a, 0x00, 0x00, 0x64, 0x65, 0x73, 0x74 \
Packit f0b94e
    }                                                \
Packit f0b94e
  }
Packit f0b94e
Packit f0b94e
#define NS_DECL_NSLOCALFILE_UNICODE_METHODS                           \
Packit f0b94e
  nsresult AppendUnicode(const char16_t *aNode);                      \
Packit f0b94e
  nsresult GetUnicodeLeafName(char16_t **aLeafName);                  \
Packit f0b94e
  nsresult SetUnicodeLeafName(const char16_t *aLeafName);             \
Packit f0b94e
  nsresult CopyToUnicode(nsIFile *aNewParentDir,                      \
Packit f0b94e
                         const char16_t *aNewLeafName);               \
Packit f0b94e
  nsresult CopyToFollowingLinksUnicode(nsIFile *aNewParentDir,        \
Packit f0b94e
                                       const char16_t *aNewLeafName); \
Packit f0b94e
  nsresult MoveToUnicode(nsIFile *aNewParentDir,                      \
Packit f0b94e
                         const char16_t *aNewLeafName);               \
Packit f0b94e
  nsresult GetUnicodeTarget(char16_t **aTarget);                      \
Packit f0b94e
  nsresult GetUnicodePath(char16_t **aPath);                          \
Packit f0b94e
  nsresult InitWithUnicodePath(const char16_t *aPath);                \
Packit f0b94e
  nsresult AppendRelativeUnicodePath(const char16_t *aRelativePath);
Packit f0b94e
Packit f0b94e
// XPCOMInit needs to know about how we are implemented,
Packit f0b94e
// so here we will export it.  Other users should not depend
Packit f0b94e
// on this.
Packit f0b94e
Packit f0b94e
#include <errno.h>
Packit f0b94e
#include "nsIFile.h"
Packit f0b94e
Packit f0b94e
#ifdef XP_WIN
Packit f0b94e
#include "nsLocalFileWin.h"
Packit f0b94e
#elif defined(XP_UNIX)
Packit f0b94e
#include "nsLocalFileUnix.h"
Packit f0b94e
#else
Packit f0b94e
#error NOT_IMPLEMENTED
Packit f0b94e
#endif
Packit f0b94e
Packit f0b94e
#define NSRESULT_FOR_RETURN(ret) (((ret) < 0) ? NSRESULT_FOR_ERRNO() : NS_OK)
Packit f0b94e
Packit f0b94e
inline nsresult nsresultForErrno(int aErr) {
Packit f0b94e
  switch (aErr) {
Packit f0b94e
    case 0:
Packit f0b94e
      return NS_OK;
Packit f0b94e
#ifdef EDQUOT
Packit f0b94e
    case EDQUOT: /* Quota exceeded */
Packit f0b94e
                 // FALLTHROUGH to return NS_ERROR_FILE_DISK_FULL
Packit f0b94e
#endif
Packit f0b94e
    case ENOSPC:
Packit f0b94e
      return NS_ERROR_FILE_DISK_FULL;
Packit f0b94e
#ifdef EISDIR
Packit f0b94e
    case EISDIR: /*      Is a directory. */
Packit f0b94e
      return NS_ERROR_FILE_IS_DIRECTORY;
Packit f0b94e
#endif
Packit f0b94e
    case ENAMETOOLONG:
Packit f0b94e
      return NS_ERROR_FILE_NAME_TOO_LONG;
Packit f0b94e
    case ENOEXEC: /*     Executable file format error. */
Packit f0b94e
      return NS_ERROR_FILE_EXECUTION_FAILED;
Packit f0b94e
    case ENOENT:
Packit f0b94e
      return NS_ERROR_FILE_TARGET_DOES_NOT_EXIST;
Packit f0b94e
    case ENOTDIR:
Packit f0b94e
      return NS_ERROR_FILE_DESTINATION_NOT_DIR;
Packit f0b94e
#ifdef ELOOP
Packit f0b94e
    case ELOOP:
Packit f0b94e
      return NS_ERROR_FILE_UNRESOLVABLE_SYMLINK;
Packit f0b94e
#endif /* ELOOP */
Packit f0b94e
#ifdef ENOLINK
Packit f0b94e
    case ENOLINK:
Packit f0b94e
      return NS_ERROR_FILE_UNRESOLVABLE_SYMLINK;
Packit f0b94e
#endif /* ENOLINK */
Packit f0b94e
    case EEXIST:
Packit f0b94e
      return NS_ERROR_FILE_ALREADY_EXISTS;
Packit f0b94e
#ifdef EPERM
Packit f0b94e
    case EPERM:
Packit f0b94e
#endif /* EPERM */
Packit f0b94e
    case EACCES:
Packit f0b94e
      return NS_ERROR_FILE_ACCESS_DENIED;
Packit f0b94e
#ifdef EROFS
Packit f0b94e
    case EROFS: /*     Read-only file system. */
Packit f0b94e
      return NS_ERROR_FILE_READ_ONLY;
Packit f0b94e
#endif
Packit f0b94e
      /*
Packit f0b94e
       * On AIX 4.3, ENOTEMPTY is defined as EEXIST,
Packit f0b94e
       * so there can't be cases for both without
Packit f0b94e
       * preprocessing.
Packit f0b94e
       */
Packit f0b94e
#if ENOTEMPTY != EEXIST
Packit f0b94e
    case ENOTEMPTY:
Packit f0b94e
      return NS_ERROR_FILE_DIR_NOT_EMPTY;
Packit f0b94e
#endif /* ENOTEMPTY != EEXIST */
Packit f0b94e
    /* Note that nsIFile.createUnique() returns
Packit f0b94e
       NS_ERROR_FILE_TOO_BIG when it cannot create a temporary
Packit f0b94e
       file with a unique filename.
Packit f0b94e
       See https://developer.mozilla.org/en-US/docs/Table_Of_Errors
Packit f0b94e
       Other usages of NS_ERROR_FILE_TOO_BIG in the source tree
Packit f0b94e
       are in line with the POSIX semantics of EFBIG.
Packit f0b94e
       So this is a reasonably good approximation.
Packit f0b94e
    */
Packit f0b94e
    case EFBIG: /*     File too large. */
Packit f0b94e
      return NS_ERROR_FILE_TOO_BIG;
Packit f0b94e
Packit f0b94e
    default:
Packit f0b94e
      return NS_ERROR_FAILURE;
Packit f0b94e
  }
Packit f0b94e
}
Packit f0b94e
Packit f0b94e
#define NSRESULT_FOR_ERRNO() nsresultForErrno(errno)
Packit f0b94e
Packit f0b94e
#endif