@theia/filesystem 1.48.1 → 1.48.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (245) hide show
  1. package/README.md +30 -30
  2. package/lib/browser/breadcrumbs/filepath-breadcrumb.d.ts +15 -15
  3. package/lib/browser/breadcrumbs/filepath-breadcrumb.js +41 -41
  4. package/lib/browser/breadcrumbs/filepath-breadcrumbs-container.d.ts +13 -13
  5. package/lib/browser/breadcrumbs/filepath-breadcrumbs-container.js +70 -70
  6. package/lib/browser/breadcrumbs/filepath-breadcrumbs-contribution.d.ts +27 -27
  7. package/lib/browser/breadcrumbs/filepath-breadcrumbs-contribution.js +118 -118
  8. package/lib/browser/download/file-download-command-contribution.d.ts +18 -18
  9. package/lib/browser/download/file-download-command-contribution.js +75 -75
  10. package/lib/browser/download/file-download-frontend-module.d.ts +3 -3
  11. package/lib/browser/download/file-download-frontend-module.js +25 -25
  12. package/lib/browser/download/file-download-service.d.ts +28 -28
  13. package/lib/browser/download/file-download-service.js +167 -167
  14. package/lib/browser/file-dialog/file-dialog-container.d.ts +5 -5
  15. package/lib/browser/file-dialog/file-dialog-container.js +60 -60
  16. package/lib/browser/file-dialog/file-dialog-hidden-files-renderer.d.ts +15 -15
  17. package/lib/browser/file-dialog/file-dialog-hidden-files-renderer.js +59 -59
  18. package/lib/browser/file-dialog/file-dialog-model.d.ts +25 -25
  19. package/lib/browser/file-dialog/file-dialog-model.js +100 -100
  20. package/lib/browser/file-dialog/file-dialog-module.d.ts +3 -3
  21. package/lib/browser/file-dialog/file-dialog-module.js +45 -45
  22. package/lib/browser/file-dialog/file-dialog-service.d.ts +32 -32
  23. package/lib/browser/file-dialog/file-dialog-service.js +101 -101
  24. package/lib/browser/file-dialog/file-dialog-tree-filters-renderer.d.ts +39 -39
  25. package/lib/browser/file-dialog/file-dialog-tree-filters-renderer.js +81 -81
  26. package/lib/browser/file-dialog/file-dialog-tree.d.ts +26 -26
  27. package/lib/browser/file-dialog/file-dialog-tree.js +83 -83
  28. package/lib/browser/file-dialog/file-dialog-widget.d.ts +15 -15
  29. package/lib/browser/file-dialog/file-dialog-widget.js +75 -75
  30. package/lib/browser/file-dialog/file-dialog.d.ts +129 -129
  31. package/lib/browser/file-dialog/file-dialog.js +351 -351
  32. package/lib/browser/file-dialog/index.d.ts +4 -4
  33. package/lib/browser/file-dialog/index.js +22 -22
  34. package/lib/browser/file-resource.d.ts +67 -67
  35. package/lib/browser/file-resource.js +369 -369
  36. package/lib/browser/file-selection.d.ts +14 -14
  37. package/lib/browser/file-selection.js +36 -36
  38. package/lib/browser/file-service.d.ts +425 -425
  39. package/lib/browser/file-service.js +1366 -1366
  40. package/lib/browser/file-tree/file-tree-container.d.ts +3 -3
  41. package/lib/browser/file-tree/file-tree-container.js +35 -35
  42. package/lib/browser/file-tree/file-tree-decorator-adapter.d.ts +30 -30
  43. package/lib/browser/file-tree/file-tree-decorator-adapter.js +169 -169
  44. package/lib/browser/file-tree/file-tree-label-provider.d.ts +12 -12
  45. package/lib/browser/file-tree/file-tree-label-provider.js +54 -54
  46. package/lib/browser/file-tree/file-tree-model.d.ts +37 -37
  47. package/lib/browser/file-tree/file-tree-model.js +217 -217
  48. package/lib/browser/file-tree/file-tree-widget.d.ts +44 -44
  49. package/lib/browser/file-tree/file-tree-widget.js +317 -317
  50. package/lib/browser/file-tree/file-tree.d.ts +46 -46
  51. package/lib/browser/file-tree/file-tree.js +176 -176
  52. package/lib/browser/file-tree/index.d.ts +6 -6
  53. package/lib/browser/file-tree/index.js +24 -24
  54. package/lib/browser/file-upload-service.d.ts +109 -109
  55. package/lib/browser/file-upload-service.js +434 -434
  56. package/lib/browser/filesystem-frontend-contribution.d.ts +74 -74
  57. package/lib/browser/filesystem-frontend-contribution.js +356 -356
  58. package/lib/browser/filesystem-frontend-module.d.ts +5 -5
  59. package/lib/browser/filesystem-frontend-module.js +64 -64
  60. package/lib/browser/filesystem-preferences.d.ts +29 -29
  61. package/lib/browser/filesystem-preferences.js +110 -110
  62. package/lib/browser/filesystem-save-resource-service.d.ts +29 -29
  63. package/lib/browser/filesystem-save-resource-service.js +135 -135
  64. package/lib/browser/filesystem-watcher-error-handler.d.ts +10 -10
  65. package/lib/browser/filesystem-watcher-error-handler.js +61 -61
  66. package/lib/browser/index.d.ts +5 -5
  67. package/lib/browser/index.js +23 -23
  68. package/lib/browser/location/index.d.ts +2 -2
  69. package/lib/browser/location/index.js +20 -20
  70. package/lib/browser/location/location-renderer.d.ts +100 -100
  71. package/lib/browser/location/location-renderer.js +343 -343
  72. package/lib/browser/location/location-service.d.ts +5 -5
  73. package/lib/browser/location/location-service.js +17 -17
  74. package/lib/browser/remote-file-service-contribution.d.ts +6 -6
  75. package/lib/browser/remote-file-service-contribution.js +39 -39
  76. package/lib/browser-only/browser-only-filesystem-frontend-module.d.ts +3 -3
  77. package/lib/browser-only/browser-only-filesystem-frontend-module.js +40 -40
  78. package/lib/browser-only/browser-only-filesystem-provider-server.d.ts +11 -11
  79. package/lib/browser-only/browser-only-filesystem-provider-server.js +39 -39
  80. package/lib/browser-only/browserfs-filesystem-initialization.d.ts +12 -12
  81. package/lib/browser-only/browserfs-filesystem-initialization.js +54 -54
  82. package/lib/browser-only/browserfs-filesystem-provider.d.ts +45 -45
  83. package/lib/browser-only/browserfs-filesystem-provider.js +439 -439
  84. package/lib/common/delegating-file-system-provider.d.ts +76 -76
  85. package/lib/common/delegating-file-system-provider.js +168 -168
  86. package/lib/common/download/file-download-data.d.ts +6 -6
  87. package/lib/common/download/file-download-data.js +26 -26
  88. package/lib/common/file-upload.d.ts +1 -1
  89. package/lib/common/file-upload.js +19 -19
  90. package/lib/common/files.d.ts +659 -659
  91. package/lib/common/files.js +355 -355
  92. package/lib/common/files.spec.d.ts +1 -1
  93. package/lib/common/files.spec.js +51 -51
  94. package/lib/common/filesystem-utils.d.ts +14 -14
  95. package/lib/common/filesystem-utils.js +63 -63
  96. package/lib/common/filesystem-utils.spec.d.ts +1 -1
  97. package/lib/common/filesystem-utils.spec.js +378 -378
  98. package/lib/common/filesystem-watcher-protocol.d.ts +71 -71
  99. package/lib/common/filesystem-watcher-protocol.js +20 -20
  100. package/lib/common/filesystem.d.ts +22 -22
  101. package/lib/common/filesystem.js +42 -42
  102. package/lib/common/index.d.ts +2 -2
  103. package/lib/common/index.js +20 -20
  104. package/lib/common/io.d.ts +19 -19
  105. package/lib/common/io.js +110 -110
  106. package/lib/common/remote-file-system-provider.d.ts +173 -173
  107. package/lib/common/remote-file-system-provider.js +435 -435
  108. package/lib/electron-browser/file-dialog/electron-file-dialog-module.d.ts +3 -3
  109. package/lib/electron-browser/file-dialog/electron-file-dialog-module.js +24 -24
  110. package/lib/electron-browser/file-dialog/electron-file-dialog-service.d.ts +19 -19
  111. package/lib/electron-browser/file-dialog/electron-file-dialog-service.js +148 -148
  112. package/lib/electron-browser/preload.d.ts +1 -1
  113. package/lib/electron-browser/preload.js +30 -30
  114. package/lib/electron-common/electron-api.d.ts +34 -34
  115. package/lib/electron-common/electron-api.js +20 -20
  116. package/lib/electron-main/electron-api-main.d.ts +5 -5
  117. package/lib/electron-main/electron-api-main.js +73 -73
  118. package/lib/electron-main/electron-main-module.d.ts +3 -3
  119. package/lib/electron-main/electron-main-module.js +24 -24
  120. package/lib/node/disk-file-system-provider.d.ts +72 -72
  121. package/lib/node/disk-file-system-provider.js +787 -787
  122. package/lib/node/disk-file-system-provider.spec.d.ts +1 -1
  123. package/lib/node/disk-file-system-provider.spec.js +122 -122
  124. package/lib/node/download/directory-archiver.d.ts +9 -9
  125. package/lib/node/download/directory-archiver.js +127 -127
  126. package/lib/node/download/directory-archiver.spec.d.ts +1 -1
  127. package/lib/node/download/directory-archiver.spec.js +97 -97
  128. package/lib/node/download/file-download-backend-module.d.ts +3 -3
  129. package/lib/node/download/file-download-backend-module.js +32 -32
  130. package/lib/node/download/file-download-cache.d.ts +21 -21
  131. package/lib/node/download/file-download-cache.js +82 -82
  132. package/lib/node/download/file-download-endpoint.d.ts +11 -11
  133. package/lib/node/download/file-download-endpoint.js +67 -67
  134. package/lib/node/download/file-download-handler.d.ts +50 -50
  135. package/lib/node/download/file-download-handler.js +307 -307
  136. package/lib/node/download/test/mock-directory-archiver.d.ts +7 -7
  137. package/lib/node/download/test/mock-directory-archiver.js +29 -29
  138. package/lib/node/file-change-collection.d.ts +22 -22
  139. package/lib/node/file-change-collection.js +77 -77
  140. package/lib/node/file-change-collection.spec.d.ts +1 -1
  141. package/lib/node/file-change-collection.spec.js +90 -90
  142. package/lib/node/filesystem-backend-module.d.ts +26 -26
  143. package/lib/node/filesystem-backend-module.js +120 -120
  144. package/lib/node/filesystem-watcher-client.d.ts +23 -23
  145. package/lib/node/filesystem-watcher-client.js +75 -75
  146. package/lib/node/filesystem-watcher-dispatcher.d.ts +23 -23
  147. package/lib/node/filesystem-watcher-dispatcher.js +80 -80
  148. package/lib/node/node-file-upload-service.d.ts +16 -16
  149. package/lib/node/node-file-upload-service.js +79 -79
  150. package/lib/node/nsfw-watcher/index.d.ts +3 -3
  151. package/lib/node/nsfw-watcher/index.js +39 -39
  152. package/lib/node/nsfw-watcher/nsfw-filesystem-service.d.ts +191 -191
  153. package/lib/node/nsfw-watcher/nsfw-filesystem-service.js +405 -405
  154. package/lib/node/nsfw-watcher/nsfw-filesystem-watcher.spec.d.ts +1 -1
  155. package/lib/node/nsfw-watcher/nsfw-filesystem-watcher.spec.js +151 -151
  156. package/lib/node/nsfw-watcher/nsfw-options.d.ts +6 -6
  157. package/lib/node/nsfw-watcher/nsfw-options.js +22 -22
  158. package/package.json +4 -4
  159. package/src/browser/breadcrumbs/filepath-breadcrumb.ts +43 -43
  160. package/src/browser/breadcrumbs/filepath-breadcrumbs-container.ts +65 -65
  161. package/src/browser/breadcrumbs/filepath-breadcrumbs-contribution.ts +129 -129
  162. package/src/browser/download/file-download-command-contribution.ts +83 -83
  163. package/src/browser/download/file-download-frontend-module.ts +25 -25
  164. package/src/browser/download/file-download-service.ts +179 -179
  165. package/src/browser/file-dialog/file-dialog-container.ts +67 -67
  166. package/src/browser/file-dialog/file-dialog-hidden-files-renderer.tsx +59 -59
  167. package/src/browser/file-dialog/file-dialog-model.ts +96 -96
  168. package/src/browser/file-dialog/file-dialog-module.ts +44 -44
  169. package/src/browser/file-dialog/file-dialog-service.ts +99 -99
  170. package/src/browser/file-dialog/file-dialog-tree-filters-renderer.tsx +100 -100
  171. package/src/browser/file-dialog/file-dialog-tree.ts +89 -89
  172. package/src/browser/file-dialog/file-dialog-widget.ts +75 -75
  173. package/src/browser/file-dialog/file-dialog.ts +434 -434
  174. package/src/browser/file-dialog/index.ts +20 -20
  175. package/src/browser/file-resource.ts +390 -390
  176. package/src/browser/file-selection.ts +44 -44
  177. package/src/browser/file-service.ts +1841 -1841
  178. package/src/browser/file-tree/file-tree-container.ts +36 -36
  179. package/src/browser/file-tree/file-tree-decorator-adapter.ts +159 -159
  180. package/src/browser/file-tree/file-tree-label-provider.ts +53 -53
  181. package/src/browser/file-tree/file-tree-model.ts +212 -212
  182. package/src/browser/file-tree/file-tree-widget.tsx +327 -327
  183. package/src/browser/file-tree/file-tree.ts +183 -183
  184. package/src/browser/file-tree/index.ts +22 -22
  185. package/src/browser/file-upload-service.ts +539 -539
  186. package/src/browser/filesystem-frontend-contribution.ts +381 -381
  187. package/src/browser/filesystem-frontend-module.ts +77 -77
  188. package/src/browser/filesystem-preferences.ts +139 -139
  189. package/src/browser/filesystem-save-resource-service.ts +125 -125
  190. package/src/browser/filesystem-watcher-error-handler.ts +60 -60
  191. package/src/browser/index.ts +21 -21
  192. package/src/browser/location/index.ts +18 -18
  193. package/src/browser/location/location-renderer.tsx +404 -404
  194. package/src/browser/location/location-service.ts +22 -22
  195. package/src/browser/remote-file-service-contribution.ts +38 -38
  196. package/src/browser/style/file-dialog.css +208 -208
  197. package/src/browser/style/file-icons.css +64 -64
  198. package/src/browser/style/filepath-breadcrumbs.css +20 -20
  199. package/src/browser/style/index.css +36 -36
  200. package/src/browser-only/browser-only-filesystem-frontend-module.ts +38 -38
  201. package/src/browser-only/browser-only-filesystem-provider-server.ts +32 -32
  202. package/src/browser-only/browserfs-filesystem-initialization.ts +61 -61
  203. package/src/browser-only/browserfs-filesystem-provider.ts +462 -462
  204. package/src/common/delegating-file-system-provider.ts +226 -226
  205. package/src/common/download/README.md +30 -30
  206. package/src/common/download/file-download-data.ts +27 -27
  207. package/src/common/file-upload.ts +17 -17
  208. package/src/common/files.spec.ts +51 -51
  209. package/src/common/files.ts +996 -996
  210. package/src/common/filesystem-utils.spec.ts +411 -411
  211. package/src/common/filesystem-utils.ts +64 -64
  212. package/src/common/filesystem-watcher-protocol.ts +96 -96
  213. package/src/common/filesystem.ts +43 -43
  214. package/src/common/index.ts +18 -18
  215. package/src/common/io.ts +150 -150
  216. package/src/common/remote-file-system-provider.ts +549 -549
  217. package/src/electron-browser/file-dialog/electron-file-dialog-module.ts +24 -24
  218. package/src/electron-browser/file-dialog/electron-file-dialog-service.ts +165 -165
  219. package/src/electron-browser/preload.ts +31 -31
  220. package/src/electron-common/electron-api.ts +55 -55
  221. package/src/electron-main/electron-api-main.ts +78 -78
  222. package/src/electron-main/electron-main-module.ts +23 -23
  223. package/src/node/disk-file-system-provider.spec.ts +142 -142
  224. package/src/node/disk-file-system-provider.ts +915 -915
  225. package/src/node/download/directory-archiver.spec.ts +104 -104
  226. package/src/node/download/directory-archiver.ts +126 -126
  227. package/src/node/download/file-download-backend-module.ts +32 -32
  228. package/src/node/download/file-download-cache.ts +88 -88
  229. package/src/node/download/file-download-endpoint.ts +63 -63
  230. package/src/node/download/file-download-handler.ts +304 -304
  231. package/src/node/download/test/mock-directory-archiver.ts +30 -30
  232. package/src/node/file-change-collection.spec.ts +110 -110
  233. package/src/node/file-change-collection.ts +78 -78
  234. package/src/node/filesystem-backend-module.ts +140 -140
  235. package/src/node/filesystem-watcher-client.ts +72 -72
  236. package/src/node/filesystem-watcher-dispatcher.ts +82 -82
  237. package/src/node/node-file-upload-service.ts +80 -80
  238. package/src/node/nsfw-watcher/index.ts +45 -45
  239. package/src/node/nsfw-watcher/nsfw-filesystem-service.ts +481 -481
  240. package/src/node/nsfw-watcher/nsfw-filesystem-watcher.spec.ts +182 -182
  241. package/src/node/nsfw-watcher/nsfw-options.ts +23 -23
  242. package/src/typings/dom.webkit.d.ts +77 -77
  243. package/src/typings/mv/index.d.ts +21 -21
  244. package/src/typings/nsfw/index.d.ts +18 -18
  245. package/src/typings/trash/index.d.ts +20 -20
@@ -1,440 +1,440 @@
1
- "use strict";
2
- // *****************************************************************************
3
- // Copyright (C) 2023 EclipseSource and others.
4
- //
5
- // This program and the accompanying materials are made available under the
6
- // terms of the Eclipse Public License v. 2.0 which is available at
7
- // http://www.eclipse.org/legal/epl-2.0.
8
- //
9
- // This Source Code may also be made available under the following Secondary
10
- // Licenses when the conditions for such availability set forth in the Eclipse
11
- // Public License v. 2.0 are satisfied: GNU General Public License, version 2
12
- // with the GNU Classpath Exception which is available at
13
- // https://www.gnu.org/software/classpath/license.html.
14
- //
15
- // SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
16
- // *****************************************************************************
17
- /*---------------------------------------------------------------------------------------------
18
- * Copyright (c) Microsoft Corporation. All rights reserved.
19
- * Licensed under the MIT License. See License.txt in the project root for license information.
20
- *--------------------------------------------------------------------------------------------*/
21
- // based on https://github.com/microsoft/vscode/blob/04c36be045a94fee58e5f8992d3e3fd980294a84/src/vs/platform/files/node/diskFileSystemProvider.ts
22
- Object.defineProperty(exports, "__esModule", { value: true });
23
- exports.BrowserFSFileSystemProvider = void 0;
24
- const tslib_1 = require("tslib");
25
- /* eslint-disable no-null/no-null */
26
- const inversify_1 = require("@theia/core/shared/inversify");
27
- const files_1 = require("../common/files");
28
- const core_1 = require("@theia/core");
29
- const browserfs_1 = require("browserfs");
30
- const path_1 = require("path");
31
- const promise_util_1 = require("@theia/core/lib/common/promise-util");
32
- const browserfs_filesystem_initialization_1 = require("./browserfs-filesystem-initialization");
33
- // adapted from DiskFileSystemProvider
34
- let BrowserFSFileSystemProvider = class BrowserFSFileSystemProvider {
35
- constructor(initialization) {
36
- this.initialization = initialization;
37
- this.capabilities = 2 /* FileReadWrite */;
38
- this.onDidChangeCapabilities = core_1.Event.None;
39
- this.onDidChangeFile = core_1.Event.None;
40
- this.onFileWatchError = core_1.Event.None;
41
- this.mapHandleToPos = new Map();
42
- this.writeHandles = new Set();
43
- this.canFlush = true;
44
- const init = async () => {
45
- this.mountableFS = await initialization.createMountableFileSystem();
46
- this.fs = (0, browserfs_1.BFSRequire)('fs');
47
- await initialization.initializeFS(this.fs, new Proxy(this, {
48
- get(target, prop, receiver) {
49
- if (prop === 'initialized') {
50
- return Promise.resolve(true);
51
- }
52
- return Reflect.get(target, prop, receiver);
53
- }
54
- }));
55
- return true;
56
- };
57
- this.initialized = init();
58
- }
59
- async mount(mountPoint, fs) {
60
- await this.initialized;
61
- this.mountableFS.mount(mountPoint, fs);
62
- }
63
- ;
64
- watch(_resource, _opts) {
65
- return core_1.Disposable.NULL;
66
- }
67
- async stat(resource) {
68
- await this.initialized;
69
- const path = this.toFilePath(resource);
70
- let stats;
71
- try {
72
- stats = await this.promisify(this.fs.stat)(path);
73
- }
74
- catch (error) {
75
- throw this.toFileSystemProviderError(error);
76
- }
77
- if (stats === undefined) {
78
- throw new Error(`Could not read file stat for resource '${path}'`);
79
- }
80
- return {
81
- type: this.toType(stats, /* symbolicLink */ undefined),
82
- ctime: stats.birthtime.getTime(),
83
- mtime: stats.mtime.getTime(),
84
- size: stats.size,
85
- // FIXME: missing mode, permissions
86
- };
87
- }
88
- async mkdir(resource) {
89
- await this.initialized;
90
- try {
91
- await this.promisify(this.fs.mkdir)(this.toFilePath(resource));
92
- }
93
- catch (error) {
94
- throw this.toFileSystemProviderError(error);
95
- }
96
- }
97
- async readdir(resource) {
98
- await this.initialized;
99
- try {
100
- const children = await this.promisify(this.fs.readdir)(this.toFilePath(resource));
101
- const result = [];
102
- await Promise.all(children.map(async (child) => {
103
- try {
104
- const stat = await this.stat(resource.resolve(child));
105
- result.push([child, stat.type]);
106
- }
107
- catch (error) {
108
- console.trace(error); // ignore errors for individual entries that can arise from permission denied
109
- }
110
- }));
111
- return result;
112
- }
113
- catch (error) {
114
- throw this.toFileSystemProviderError(error);
115
- }
116
- }
117
- async delete(resource, _opts) {
118
- await this.initialized;
119
- // FIXME use options
120
- try {
121
- await this.promisify(this.fs.unlink)(this.toFilePath(resource));
122
- }
123
- catch (error) {
124
- throw this.toFileSystemProviderError(error);
125
- }
126
- }
127
- async rename(from, to, opts) {
128
- await this.initialized;
129
- const fromFilePath = this.toFilePath(from);
130
- const toFilePath = this.toFilePath(to);
131
- if (fromFilePath === toFilePath) {
132
- return; // simulate node.js behaviour here and do a no-op if paths match
133
- }
134
- try {
135
- // assume FS is path case sensitive - correct?
136
- const targetExists = await this.promisify(this.fs.exists)(toFilePath);
137
- if (targetExists) {
138
- throw Error(`File '${toFilePath}' already exists.`);
139
- }
140
- if (fromFilePath === toFilePath) {
141
- return Promise.resolve();
142
- }
143
- await this.promisify(this.fs.rename)(fromFilePath, toFilePath);
144
- const stat = await this.promisify(this.fs.lstat)(toFilePath);
145
- if (stat.isDirectory() || stat.isSymbolicLink()) {
146
- return Promise.resolve(); // only for files
147
- }
148
- const fd = await this.promisify(open)(toFilePath, 'a');
149
- try {
150
- await this.promisify(this.fs.futimes)(fd, stat.atime, new Date());
151
- }
152
- catch (error) {
153
- // ignore
154
- }
155
- this.promisify(this.fs.close)(fd);
156
- }
157
- catch (error) {
158
- // rewrite some typical errors that can happen especially around symlinks
159
- // to something the user can better understand
160
- if (error.code === 'EINVAL' || error.code === 'EBUSY' || error.code === 'ENAMETOOLONG') {
161
- error = new Error(`Unable to move '${(0, path_1.basename)(fromFilePath)}' into '${(0, path_1.basename)((0, path_1.dirname)(toFilePath))}' (${error.toString()}).`);
162
- }
163
- throw this.toFileSystemProviderError(error);
164
- }
165
- }
166
- async copy(from, to, opts) {
167
- await this.initialized;
168
- throw new Error('Method not implemented.');
169
- }
170
- async readFile(resource) {
171
- await this.initialized;
172
- try {
173
- const filePath = this.toFilePath(resource);
174
- return await this.promisify(this.fs.readFile)(filePath);
175
- }
176
- catch (error) {
177
- throw this.toFileSystemProviderError(error);
178
- }
179
- }
180
- async writeFile(resource, content, opts) {
181
- await this.initialized;
182
- let handle = undefined;
183
- try {
184
- const filePath = this.toFilePath(resource);
185
- // Validate target unless { create: true, overwrite: true }
186
- if (!opts.create || !opts.overwrite) {
187
- const fileExists = await this.promisify(this.fs.exists)(filePath);
188
- if (fileExists) {
189
- if (!opts.overwrite) {
190
- throw (0, files_1.createFileSystemProviderError)('File already exists', files_1.FileSystemProviderErrorCode.FileExists);
191
- }
192
- }
193
- else {
194
- if (!opts.create) {
195
- throw (0, files_1.createFileSystemProviderError)('File does not exist', files_1.FileSystemProviderErrorCode.FileNotFound);
196
- }
197
- }
198
- }
199
- // Open
200
- handle = await this.open(resource, { create: true });
201
- // Write content at once
202
- await this.write(handle, 0, content, 0, content.byteLength);
203
- }
204
- catch (error) {
205
- throw this.toFileSystemProviderError(error);
206
- }
207
- finally {
208
- if (typeof handle === 'number') {
209
- await this.close(handle);
210
- }
211
- }
212
- }
213
- readFileStream(resource, opts, token) {
214
- throw new Error('Method not implemented.');
215
- }
216
- async open(resource, opts) {
217
- await this.initialized;
218
- try {
219
- const filePath = this.toFilePath(resource);
220
- let flags = undefined;
221
- if (opts.create) {
222
- // we take opts.create as a hint that the file is opened for writing
223
- // as such we use 'w' to truncate an existing or create the
224
- // file otherwise. we do not allow reading.
225
- if (!flags) {
226
- flags = 'w';
227
- }
228
- }
229
- else {
230
- // otherwise we assume the file is opened for reading
231
- // as such we use 'r' to neither truncate, nor create
232
- // the file.
233
- flags = 'r';
234
- }
235
- const handle = await this.promisify(this.fs.open)(filePath, flags);
236
- // remember this handle to track file position of the handle
237
- // we init the position to 0 since the file descriptor was
238
- // just created and the position was not moved so far (see
239
- // also http://man7.org/linux/man-pages/man2/open.2.html -
240
- // "The file offset is set to the beginning of the file.")
241
- this.mapHandleToPos.set(handle, 0);
242
- // remember that this handle was used for writing
243
- if (opts.create) {
244
- this.writeHandles.add(handle);
245
- }
246
- return handle;
247
- }
248
- catch (error) {
249
- throw this.toFileSystemProviderError(error);
250
- }
251
- }
252
- async close(fd) {
253
- await this.initialized;
254
- // remove this handle from map of positions
255
- this.mapHandleToPos.delete(fd);
256
- // if a handle is closed that was used for writing, ensure
257
- // to flush the contents to disk if possible.
258
- if (this.writeHandles.delete(fd) && this.canFlush) {
259
- try {
260
- await this.promisify(this.fs.fdatasync)(fd);
261
- }
262
- catch (error) {
263
- // In some exotic setups it is well possible that node fails to sync
264
- // In that case we disable flushing and log the error to our logger
265
- this.canFlush = false;
266
- console.error(error);
267
- }
268
- }
269
- await this.promisify(this.fs.close)(fd);
270
- }
271
- async read(fd, pos, data, offset, length) {
272
- await this.initialized;
273
- const normalizedPos = this.normalizePos(fd, pos);
274
- let bytesRead = null;
275
- try {
276
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
277
- const result = (await this.promisify(this.fs.read)(fd, data, offset, length, normalizedPos));
278
- if (typeof result === 'number') {
279
- bytesRead = result; // node.d.ts fail
280
- }
281
- else {
282
- bytesRead = result.bytesRead;
283
- }
284
- return bytesRead;
285
- }
286
- catch (error) {
287
- throw this.toFileSystemProviderError(error);
288
- }
289
- finally {
290
- this.updatePos(fd, normalizedPos, bytesRead);
291
- }
292
- }
293
- async write(fd, pos, data, offset, length) {
294
- await this.initialized;
295
- // we know at this point that the file to write to is truncated and thus empty
296
- // if the write now fails, the file remains empty. as such we really try hard
297
- // to ensure the write succeeds by retrying up to three times.
298
- return (0, promise_util_1.retry)(() => this.doWrite(fd, pos, data, offset, length), 100 /* ms delay */, 3 /* retries */);
299
- }
300
- async doWrite(fd, pos, data, offset, length) {
301
- await this.initialized;
302
- const normalizedPos = this.normalizePos(fd, pos);
303
- let bytesWritten = null;
304
- try {
305
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
306
- const result = (await this.promisify(this.fs.write)(fd, data, offset, length, normalizedPos));
307
- if (typeof result === 'number') {
308
- bytesWritten = result; // node.d.ts fail
309
- }
310
- else {
311
- bytesWritten = result.bytesWritten;
312
- }
313
- return bytesWritten;
314
- }
315
- catch (error) {
316
- throw this.toFileSystemProviderError(error);
317
- }
318
- finally {
319
- this.updatePos(fd, normalizedPos, bytesWritten);
320
- }
321
- }
322
- normalizePos(fd, pos) {
323
- // when calling fs.read/write we try to avoid passing in the "pos" argument and
324
- // rather prefer to pass in "null" because this avoids an extra seek(pos)
325
- // call that in some cases can even fail (e.g. when opening a file over FTP -
326
- // see https://github.com/microsoft/vscode/issues/73884).
327
- //
328
- // as such, we compare the passed in position argument with our last known
329
- // position for the file descriptor and use "null" if they match.
330
- if (pos === this.mapHandleToPos.get(fd)) {
331
- return null;
332
- }
333
- return pos;
334
- }
335
- updatePos(fd, pos, bytesLength) {
336
- const lastKnownPos = this.mapHandleToPos.get(fd);
337
- if (typeof lastKnownPos === 'number') {
338
- // pos !== null signals that previously a position was used that is
339
- // not null. node.js documentation explains, that in this case
340
- // the internal file pointer is not moving and as such we do not move
341
- // our position pointer.
342
- //
343
- // Docs: "If position is null, data will be read from the current file position,
344
- // and the file position will be updated. If position is an integer, the file position
345
- // will remain unchanged."
346
- if (typeof pos === 'number') {
347
- // do not modify the position
348
- }
349
- else if (typeof bytesLength === 'number') {
350
- this.mapHandleToPos.set(fd, lastKnownPos + bytesLength);
351
- }
352
- else {
353
- this.mapHandleToPos.delete(fd);
354
- }
355
- }
356
- }
357
- async access(resource, mode) {
358
- await this.initialized;
359
- throw new Error('Method not implemented.');
360
- }
361
- async fsPath(resource) {
362
- await this.initialized;
363
- throw new Error('Method not implemented.');
364
- }
365
- async updateFile(resource, changes, opts) {
366
- await this.initialized;
367
- throw new Error('Method not implemented.');
368
- }
369
- toFilePath(resource) {
370
- return (0, path_1.normalize)(resource.path.toString());
371
- }
372
- toType(entry, symbolicLink) {
373
- // Signal file type by checking for file / directory, except:
374
- // - symbolic links pointing to non-existing files are FileType.Unknown
375
- // - files that are neither file nor directory are FileType.Unknown
376
- let type;
377
- if (symbolicLink === null || symbolicLink === void 0 ? void 0 : symbolicLink.dangling) {
378
- type = files_1.FileType.Unknown;
379
- }
380
- else if (entry.isFile()) {
381
- type = files_1.FileType.File;
382
- }
383
- else if (entry.isDirectory()) {
384
- type = files_1.FileType.Directory;
385
- }
386
- else {
387
- type = files_1.FileType.Unknown;
388
- }
389
- // Always signal symbolic link as file type additionally
390
- if (symbolicLink) {
391
- type |= files_1.FileType.SymbolicLink;
392
- }
393
- return type;
394
- }
395
- // FIXME typing
396
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
397
- promisify(f) {
398
- // eslint-disable-next-line @typescript-eslint/tslint/config, @typescript-eslint/no-explicit-any
399
- return function (...args) {
400
- return new Promise((resolve, reject) => {
401
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
402
- f(...args, (err, result) => err ? reject(err) : resolve(result));
403
- });
404
- };
405
- }
406
- toFileSystemProviderError(error) {
407
- if (error instanceof files_1.FileSystemProviderError) {
408
- return error; // avoid double conversion
409
- }
410
- let code;
411
- switch (error.code) {
412
- case 'ENOENT':
413
- code = files_1.FileSystemProviderErrorCode.FileNotFound;
414
- break;
415
- case 'EISDIR':
416
- code = files_1.FileSystemProviderErrorCode.FileIsADirectory;
417
- break;
418
- case 'ENOTDIR':
419
- code = files_1.FileSystemProviderErrorCode.FileNotADirectory;
420
- break;
421
- case 'EEXIST':
422
- code = files_1.FileSystemProviderErrorCode.FileExists;
423
- break;
424
- case 'EPERM':
425
- case 'EACCES':
426
- code = files_1.FileSystemProviderErrorCode.NoPermissions;
427
- break;
428
- default:
429
- code = files_1.FileSystemProviderErrorCode.Unknown;
430
- }
431
- return (0, files_1.createFileSystemProviderError)(error, code);
432
- }
433
- };
434
- BrowserFSFileSystemProvider = (0, tslib_1.__decorate)([
435
- (0, inversify_1.injectable)(),
436
- (0, tslib_1.__param)(0, (0, inversify_1.inject)(browserfs_filesystem_initialization_1.BrowserFSInitialization)),
437
- (0, tslib_1.__metadata)("design:paramtypes", [Object])
438
- ], BrowserFSFileSystemProvider);
439
- exports.BrowserFSFileSystemProvider = BrowserFSFileSystemProvider;
1
+ "use strict";
2
+ // *****************************************************************************
3
+ // Copyright (C) 2023 EclipseSource and others.
4
+ //
5
+ // This program and the accompanying materials are made available under the
6
+ // terms of the Eclipse Public License v. 2.0 which is available at
7
+ // http://www.eclipse.org/legal/epl-2.0.
8
+ //
9
+ // This Source Code may also be made available under the following Secondary
10
+ // Licenses when the conditions for such availability set forth in the Eclipse
11
+ // Public License v. 2.0 are satisfied: GNU General Public License, version 2
12
+ // with the GNU Classpath Exception which is available at
13
+ // https://www.gnu.org/software/classpath/license.html.
14
+ //
15
+ // SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
16
+ // *****************************************************************************
17
+ /*---------------------------------------------------------------------------------------------
18
+ * Copyright (c) Microsoft Corporation. All rights reserved.
19
+ * Licensed under the MIT License. See License.txt in the project root for license information.
20
+ *--------------------------------------------------------------------------------------------*/
21
+ // based on https://github.com/microsoft/vscode/blob/04c36be045a94fee58e5f8992d3e3fd980294a84/src/vs/platform/files/node/diskFileSystemProvider.ts
22
+ Object.defineProperty(exports, "__esModule", { value: true });
23
+ exports.BrowserFSFileSystemProvider = void 0;
24
+ const tslib_1 = require("tslib");
25
+ /* eslint-disable no-null/no-null */
26
+ const inversify_1 = require("@theia/core/shared/inversify");
27
+ const files_1 = require("../common/files");
28
+ const core_1 = require("@theia/core");
29
+ const browserfs_1 = require("browserfs");
30
+ const path_1 = require("path");
31
+ const promise_util_1 = require("@theia/core/lib/common/promise-util");
32
+ const browserfs_filesystem_initialization_1 = require("./browserfs-filesystem-initialization");
33
+ // adapted from DiskFileSystemProvider
34
+ let BrowserFSFileSystemProvider = class BrowserFSFileSystemProvider {
35
+ constructor(initialization) {
36
+ this.initialization = initialization;
37
+ this.capabilities = 2 /* FileReadWrite */;
38
+ this.onDidChangeCapabilities = core_1.Event.None;
39
+ this.onDidChangeFile = core_1.Event.None;
40
+ this.onFileWatchError = core_1.Event.None;
41
+ this.mapHandleToPos = new Map();
42
+ this.writeHandles = new Set();
43
+ this.canFlush = true;
44
+ const init = async () => {
45
+ this.mountableFS = await initialization.createMountableFileSystem();
46
+ this.fs = (0, browserfs_1.BFSRequire)('fs');
47
+ await initialization.initializeFS(this.fs, new Proxy(this, {
48
+ get(target, prop, receiver) {
49
+ if (prop === 'initialized') {
50
+ return Promise.resolve(true);
51
+ }
52
+ return Reflect.get(target, prop, receiver);
53
+ }
54
+ }));
55
+ return true;
56
+ };
57
+ this.initialized = init();
58
+ }
59
+ async mount(mountPoint, fs) {
60
+ await this.initialized;
61
+ this.mountableFS.mount(mountPoint, fs);
62
+ }
63
+ ;
64
+ watch(_resource, _opts) {
65
+ return core_1.Disposable.NULL;
66
+ }
67
+ async stat(resource) {
68
+ await this.initialized;
69
+ const path = this.toFilePath(resource);
70
+ let stats;
71
+ try {
72
+ stats = await this.promisify(this.fs.stat)(path);
73
+ }
74
+ catch (error) {
75
+ throw this.toFileSystemProviderError(error);
76
+ }
77
+ if (stats === undefined) {
78
+ throw new Error(`Could not read file stat for resource '${path}'`);
79
+ }
80
+ return {
81
+ type: this.toType(stats, /* symbolicLink */ undefined),
82
+ ctime: stats.birthtime.getTime(),
83
+ mtime: stats.mtime.getTime(),
84
+ size: stats.size,
85
+ // FIXME: missing mode, permissions
86
+ };
87
+ }
88
+ async mkdir(resource) {
89
+ await this.initialized;
90
+ try {
91
+ await this.promisify(this.fs.mkdir)(this.toFilePath(resource));
92
+ }
93
+ catch (error) {
94
+ throw this.toFileSystemProviderError(error);
95
+ }
96
+ }
97
+ async readdir(resource) {
98
+ await this.initialized;
99
+ try {
100
+ const children = await this.promisify(this.fs.readdir)(this.toFilePath(resource));
101
+ const result = [];
102
+ await Promise.all(children.map(async (child) => {
103
+ try {
104
+ const stat = await this.stat(resource.resolve(child));
105
+ result.push([child, stat.type]);
106
+ }
107
+ catch (error) {
108
+ console.trace(error); // ignore errors for individual entries that can arise from permission denied
109
+ }
110
+ }));
111
+ return result;
112
+ }
113
+ catch (error) {
114
+ throw this.toFileSystemProviderError(error);
115
+ }
116
+ }
117
+ async delete(resource, _opts) {
118
+ await this.initialized;
119
+ // FIXME use options
120
+ try {
121
+ await this.promisify(this.fs.unlink)(this.toFilePath(resource));
122
+ }
123
+ catch (error) {
124
+ throw this.toFileSystemProviderError(error);
125
+ }
126
+ }
127
+ async rename(from, to, opts) {
128
+ await this.initialized;
129
+ const fromFilePath = this.toFilePath(from);
130
+ const toFilePath = this.toFilePath(to);
131
+ if (fromFilePath === toFilePath) {
132
+ return; // simulate node.js behaviour here and do a no-op if paths match
133
+ }
134
+ try {
135
+ // assume FS is path case sensitive - correct?
136
+ const targetExists = await this.promisify(this.fs.exists)(toFilePath);
137
+ if (targetExists) {
138
+ throw Error(`File '${toFilePath}' already exists.`);
139
+ }
140
+ if (fromFilePath === toFilePath) {
141
+ return Promise.resolve();
142
+ }
143
+ await this.promisify(this.fs.rename)(fromFilePath, toFilePath);
144
+ const stat = await this.promisify(this.fs.lstat)(toFilePath);
145
+ if (stat.isDirectory() || stat.isSymbolicLink()) {
146
+ return Promise.resolve(); // only for files
147
+ }
148
+ const fd = await this.promisify(open)(toFilePath, 'a');
149
+ try {
150
+ await this.promisify(this.fs.futimes)(fd, stat.atime, new Date());
151
+ }
152
+ catch (error) {
153
+ // ignore
154
+ }
155
+ this.promisify(this.fs.close)(fd);
156
+ }
157
+ catch (error) {
158
+ // rewrite some typical errors that can happen especially around symlinks
159
+ // to something the user can better understand
160
+ if (error.code === 'EINVAL' || error.code === 'EBUSY' || error.code === 'ENAMETOOLONG') {
161
+ error = new Error(`Unable to move '${(0, path_1.basename)(fromFilePath)}' into '${(0, path_1.basename)((0, path_1.dirname)(toFilePath))}' (${error.toString()}).`);
162
+ }
163
+ throw this.toFileSystemProviderError(error);
164
+ }
165
+ }
166
+ async copy(from, to, opts) {
167
+ await this.initialized;
168
+ throw new Error('Method not implemented.');
169
+ }
170
+ async readFile(resource) {
171
+ await this.initialized;
172
+ try {
173
+ const filePath = this.toFilePath(resource);
174
+ return await this.promisify(this.fs.readFile)(filePath);
175
+ }
176
+ catch (error) {
177
+ throw this.toFileSystemProviderError(error);
178
+ }
179
+ }
180
+ async writeFile(resource, content, opts) {
181
+ await this.initialized;
182
+ let handle = undefined;
183
+ try {
184
+ const filePath = this.toFilePath(resource);
185
+ // Validate target unless { create: true, overwrite: true }
186
+ if (!opts.create || !opts.overwrite) {
187
+ const fileExists = await this.promisify(this.fs.exists)(filePath);
188
+ if (fileExists) {
189
+ if (!opts.overwrite) {
190
+ throw (0, files_1.createFileSystemProviderError)('File already exists', files_1.FileSystemProviderErrorCode.FileExists);
191
+ }
192
+ }
193
+ else {
194
+ if (!opts.create) {
195
+ throw (0, files_1.createFileSystemProviderError)('File does not exist', files_1.FileSystemProviderErrorCode.FileNotFound);
196
+ }
197
+ }
198
+ }
199
+ // Open
200
+ handle = await this.open(resource, { create: true });
201
+ // Write content at once
202
+ await this.write(handle, 0, content, 0, content.byteLength);
203
+ }
204
+ catch (error) {
205
+ throw this.toFileSystemProviderError(error);
206
+ }
207
+ finally {
208
+ if (typeof handle === 'number') {
209
+ await this.close(handle);
210
+ }
211
+ }
212
+ }
213
+ readFileStream(resource, opts, token) {
214
+ throw new Error('Method not implemented.');
215
+ }
216
+ async open(resource, opts) {
217
+ await this.initialized;
218
+ try {
219
+ const filePath = this.toFilePath(resource);
220
+ let flags = undefined;
221
+ if (opts.create) {
222
+ // we take opts.create as a hint that the file is opened for writing
223
+ // as such we use 'w' to truncate an existing or create the
224
+ // file otherwise. we do not allow reading.
225
+ if (!flags) {
226
+ flags = 'w';
227
+ }
228
+ }
229
+ else {
230
+ // otherwise we assume the file is opened for reading
231
+ // as such we use 'r' to neither truncate, nor create
232
+ // the file.
233
+ flags = 'r';
234
+ }
235
+ const handle = await this.promisify(this.fs.open)(filePath, flags);
236
+ // remember this handle to track file position of the handle
237
+ // we init the position to 0 since the file descriptor was
238
+ // just created and the position was not moved so far (see
239
+ // also http://man7.org/linux/man-pages/man2/open.2.html -
240
+ // "The file offset is set to the beginning of the file.")
241
+ this.mapHandleToPos.set(handle, 0);
242
+ // remember that this handle was used for writing
243
+ if (opts.create) {
244
+ this.writeHandles.add(handle);
245
+ }
246
+ return handle;
247
+ }
248
+ catch (error) {
249
+ throw this.toFileSystemProviderError(error);
250
+ }
251
+ }
252
+ async close(fd) {
253
+ await this.initialized;
254
+ // remove this handle from map of positions
255
+ this.mapHandleToPos.delete(fd);
256
+ // if a handle is closed that was used for writing, ensure
257
+ // to flush the contents to disk if possible.
258
+ if (this.writeHandles.delete(fd) && this.canFlush) {
259
+ try {
260
+ await this.promisify(this.fs.fdatasync)(fd);
261
+ }
262
+ catch (error) {
263
+ // In some exotic setups it is well possible that node fails to sync
264
+ // In that case we disable flushing and log the error to our logger
265
+ this.canFlush = false;
266
+ console.error(error);
267
+ }
268
+ }
269
+ await this.promisify(this.fs.close)(fd);
270
+ }
271
+ async read(fd, pos, data, offset, length) {
272
+ await this.initialized;
273
+ const normalizedPos = this.normalizePos(fd, pos);
274
+ let bytesRead = null;
275
+ try {
276
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
277
+ const result = (await this.promisify(this.fs.read)(fd, data, offset, length, normalizedPos));
278
+ if (typeof result === 'number') {
279
+ bytesRead = result; // node.d.ts fail
280
+ }
281
+ else {
282
+ bytesRead = result.bytesRead;
283
+ }
284
+ return bytesRead;
285
+ }
286
+ catch (error) {
287
+ throw this.toFileSystemProviderError(error);
288
+ }
289
+ finally {
290
+ this.updatePos(fd, normalizedPos, bytesRead);
291
+ }
292
+ }
293
+ async write(fd, pos, data, offset, length) {
294
+ await this.initialized;
295
+ // we know at this point that the file to write to is truncated and thus empty
296
+ // if the write now fails, the file remains empty. as such we really try hard
297
+ // to ensure the write succeeds by retrying up to three times.
298
+ return (0, promise_util_1.retry)(() => this.doWrite(fd, pos, data, offset, length), 100 /* ms delay */, 3 /* retries */);
299
+ }
300
+ async doWrite(fd, pos, data, offset, length) {
301
+ await this.initialized;
302
+ const normalizedPos = this.normalizePos(fd, pos);
303
+ let bytesWritten = null;
304
+ try {
305
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
306
+ const result = (await this.promisify(this.fs.write)(fd, data, offset, length, normalizedPos));
307
+ if (typeof result === 'number') {
308
+ bytesWritten = result; // node.d.ts fail
309
+ }
310
+ else {
311
+ bytesWritten = result.bytesWritten;
312
+ }
313
+ return bytesWritten;
314
+ }
315
+ catch (error) {
316
+ throw this.toFileSystemProviderError(error);
317
+ }
318
+ finally {
319
+ this.updatePos(fd, normalizedPos, bytesWritten);
320
+ }
321
+ }
322
+ normalizePos(fd, pos) {
323
+ // when calling fs.read/write we try to avoid passing in the "pos" argument and
324
+ // rather prefer to pass in "null" because this avoids an extra seek(pos)
325
+ // call that in some cases can even fail (e.g. when opening a file over FTP -
326
+ // see https://github.com/microsoft/vscode/issues/73884).
327
+ //
328
+ // as such, we compare the passed in position argument with our last known
329
+ // position for the file descriptor and use "null" if they match.
330
+ if (pos === this.mapHandleToPos.get(fd)) {
331
+ return null;
332
+ }
333
+ return pos;
334
+ }
335
+ updatePos(fd, pos, bytesLength) {
336
+ const lastKnownPos = this.mapHandleToPos.get(fd);
337
+ if (typeof lastKnownPos === 'number') {
338
+ // pos !== null signals that previously a position was used that is
339
+ // not null. node.js documentation explains, that in this case
340
+ // the internal file pointer is not moving and as such we do not move
341
+ // our position pointer.
342
+ //
343
+ // Docs: "If position is null, data will be read from the current file position,
344
+ // and the file position will be updated. If position is an integer, the file position
345
+ // will remain unchanged."
346
+ if (typeof pos === 'number') {
347
+ // do not modify the position
348
+ }
349
+ else if (typeof bytesLength === 'number') {
350
+ this.mapHandleToPos.set(fd, lastKnownPos + bytesLength);
351
+ }
352
+ else {
353
+ this.mapHandleToPos.delete(fd);
354
+ }
355
+ }
356
+ }
357
+ async access(resource, mode) {
358
+ await this.initialized;
359
+ throw new Error('Method not implemented.');
360
+ }
361
+ async fsPath(resource) {
362
+ await this.initialized;
363
+ throw new Error('Method not implemented.');
364
+ }
365
+ async updateFile(resource, changes, opts) {
366
+ await this.initialized;
367
+ throw new Error('Method not implemented.');
368
+ }
369
+ toFilePath(resource) {
370
+ return (0, path_1.normalize)(resource.path.toString());
371
+ }
372
+ toType(entry, symbolicLink) {
373
+ // Signal file type by checking for file / directory, except:
374
+ // - symbolic links pointing to non-existing files are FileType.Unknown
375
+ // - files that are neither file nor directory are FileType.Unknown
376
+ let type;
377
+ if (symbolicLink === null || symbolicLink === void 0 ? void 0 : symbolicLink.dangling) {
378
+ type = files_1.FileType.Unknown;
379
+ }
380
+ else if (entry.isFile()) {
381
+ type = files_1.FileType.File;
382
+ }
383
+ else if (entry.isDirectory()) {
384
+ type = files_1.FileType.Directory;
385
+ }
386
+ else {
387
+ type = files_1.FileType.Unknown;
388
+ }
389
+ // Always signal symbolic link as file type additionally
390
+ if (symbolicLink) {
391
+ type |= files_1.FileType.SymbolicLink;
392
+ }
393
+ return type;
394
+ }
395
+ // FIXME typing
396
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
397
+ promisify(f) {
398
+ // eslint-disable-next-line @typescript-eslint/tslint/config, @typescript-eslint/no-explicit-any
399
+ return function (...args) {
400
+ return new Promise((resolve, reject) => {
401
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
402
+ f(...args, (err, result) => err ? reject(err) : resolve(result));
403
+ });
404
+ };
405
+ }
406
+ toFileSystemProviderError(error) {
407
+ if (error instanceof files_1.FileSystemProviderError) {
408
+ return error; // avoid double conversion
409
+ }
410
+ let code;
411
+ switch (error.code) {
412
+ case 'ENOENT':
413
+ code = files_1.FileSystemProviderErrorCode.FileNotFound;
414
+ break;
415
+ case 'EISDIR':
416
+ code = files_1.FileSystemProviderErrorCode.FileIsADirectory;
417
+ break;
418
+ case 'ENOTDIR':
419
+ code = files_1.FileSystemProviderErrorCode.FileNotADirectory;
420
+ break;
421
+ case 'EEXIST':
422
+ code = files_1.FileSystemProviderErrorCode.FileExists;
423
+ break;
424
+ case 'EPERM':
425
+ case 'EACCES':
426
+ code = files_1.FileSystemProviderErrorCode.NoPermissions;
427
+ break;
428
+ default:
429
+ code = files_1.FileSystemProviderErrorCode.Unknown;
430
+ }
431
+ return (0, files_1.createFileSystemProviderError)(error, code);
432
+ }
433
+ };
434
+ BrowserFSFileSystemProvider = (0, tslib_1.__decorate)([
435
+ (0, inversify_1.injectable)(),
436
+ (0, tslib_1.__param)(0, (0, inversify_1.inject)(browserfs_filesystem_initialization_1.BrowserFSInitialization)),
437
+ (0, tslib_1.__metadata)("design:paramtypes", [Object])
438
+ ], BrowserFSFileSystemProvider);
439
+ exports.BrowserFSFileSystemProvider = BrowserFSFileSystemProvider;
440
440
  //# sourceMappingURL=browserfs-filesystem-provider.js.map