1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
|
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
/* vim: set ts=8 sts=2 et sw=2 tw=80: */
/* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
#ifndef _NS_LOCAL_FILE_H_
#define _NS_LOCAL_FILE_H_
#include "nscore.h"
#define NS_LOCAL_FILE_CID \
{ \
0x2e23e220, 0x60be, 0x11d3, { \
0x8c, 0x4a, 0x00, 0x00, 0x64, 0x65, 0x73, 0x74 \
} \
}
#define NS_DECL_NSLOCALFILE_UNICODE_METHODS \
nsresult AppendUnicode(const char16_t* aNode); \
nsresult GetUnicodeLeafName(char16_t** aLeafName); \
nsresult SetUnicodeLeafName(const char16_t* aLeafName); \
nsresult CopyToUnicode(nsIFile* aNewParentDir, \
const char16_t* aNewLeafName); \
nsresult CopyToFollowingLinksUnicode(nsIFile* aNewParentDir, \
const char16_t* aNewLeafName); \
nsresult MoveToUnicode(nsIFile* aNewParentDir, \
const char16_t* aNewLeafName); \
nsresult GetUnicodeTarget(char16_t** aTarget); \
nsresult GetUnicodePath(char16_t** aPath); \
nsresult InitWithUnicodePath(const char16_t* aPath); \
nsresult AppendRelativeUnicodePath(const char16_t* aRelativePath);
// XPCOMInit needs to know about how we are implemented,
// so here we will export it. Other users should not depend
// on this.
#include <errno.h>
#include "nsIFile.h"
#ifdef XP_WIN
# include "nsLocalFileWin.h"
#elif defined(XP_UNIX)
# include "nsLocalFileUnix.h"
#else
# error NOT_IMPLEMENTED
#endif
#define NSRESULT_FOR_RETURN(ret) (((ret) < 0) ? NSRESULT_FOR_ERRNO() : NS_OK)
inline nsresult nsresultForErrno(int aErr) {
switch (aErr) {
case 0:
return NS_OK;
#ifdef EDQUOT
case EDQUOT: /* Quota exceeded */
[[fallthrough]]; // to NS_ERROR_FILE_NO_DEVICE_SPACE
#endif
case ENOSPC:
return NS_ERROR_FILE_NO_DEVICE_SPACE;
#ifdef EISDIR
case EISDIR: /* Is a directory. */
return NS_ERROR_FILE_IS_DIRECTORY;
#endif
case ENAMETOOLONG:
return NS_ERROR_FILE_NAME_TOO_LONG;
case ENOEXEC: /* Executable file format error. */
return NS_ERROR_FILE_EXECUTION_FAILED;
case ENOENT:
return NS_ERROR_FILE_NOT_FOUND;
case ENOTDIR:
return NS_ERROR_FILE_DESTINATION_NOT_DIR;
#ifdef ELOOP
case ELOOP:
return NS_ERROR_FILE_UNRESOLVABLE_SYMLINK;
#endif /* ELOOP */
#ifdef ENOLINK
case ENOLINK:
return NS_ERROR_FILE_UNRESOLVABLE_SYMLINK;
#endif /* ENOLINK */
case EEXIST:
return NS_ERROR_FILE_ALREADY_EXISTS;
#ifdef EPERM
case EPERM:
#endif /* EPERM */
case EACCES:
return NS_ERROR_FILE_ACCESS_DENIED;
#ifdef EROFS
case EROFS: /* Read-only file system. */
return NS_ERROR_FILE_READ_ONLY;
#endif
/*
* On AIX 4.3, ENOTEMPTY is defined as EEXIST,
* so there can't be cases for both without
* preprocessing.
*/
#if ENOTEMPTY != EEXIST
case ENOTEMPTY:
return NS_ERROR_FILE_DIR_NOT_EMPTY;
#endif /* ENOTEMPTY != EEXIST */
/* Note that nsIFile.createUnique() returns
NS_ERROR_FILE_TOO_BIG when it cannot create a temporary
file with a unique filename.
See https://developer.mozilla.org/en-US/docs/Table_Of_Errors
Other usages of NS_ERROR_FILE_TOO_BIG in the source tree
are in line with the POSIX semantics of EFBIG.
So this is a reasonably good approximation.
*/
case EFBIG: /* File too large. */
return NS_ERROR_FILE_TOO_BIG;
#ifdef ENOATTR
case ENOATTR:
return NS_ERROR_NOT_AVAILABLE;
#endif // ENOATTR
default:
return NS_ERROR_FAILURE;
}
}
#define NSRESULT_FOR_ERRNO() nsresultForErrno(errno)
#endif
|