@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.
- package/README.md +30 -30
- package/lib/browser/breadcrumbs/filepath-breadcrumb.d.ts +15 -15
- package/lib/browser/breadcrumbs/filepath-breadcrumb.js +41 -41
- package/lib/browser/breadcrumbs/filepath-breadcrumbs-container.d.ts +13 -13
- package/lib/browser/breadcrumbs/filepath-breadcrumbs-container.js +70 -70
- package/lib/browser/breadcrumbs/filepath-breadcrumbs-contribution.d.ts +27 -27
- package/lib/browser/breadcrumbs/filepath-breadcrumbs-contribution.js +118 -118
- package/lib/browser/download/file-download-command-contribution.d.ts +18 -18
- package/lib/browser/download/file-download-command-contribution.js +75 -75
- package/lib/browser/download/file-download-frontend-module.d.ts +3 -3
- package/lib/browser/download/file-download-frontend-module.js +25 -25
- package/lib/browser/download/file-download-service.d.ts +28 -28
- package/lib/browser/download/file-download-service.js +167 -167
- package/lib/browser/file-dialog/file-dialog-container.d.ts +5 -5
- package/lib/browser/file-dialog/file-dialog-container.js +60 -60
- package/lib/browser/file-dialog/file-dialog-hidden-files-renderer.d.ts +15 -15
- package/lib/browser/file-dialog/file-dialog-hidden-files-renderer.js +59 -59
- package/lib/browser/file-dialog/file-dialog-model.d.ts +25 -25
- package/lib/browser/file-dialog/file-dialog-model.js +100 -100
- package/lib/browser/file-dialog/file-dialog-module.d.ts +3 -3
- package/lib/browser/file-dialog/file-dialog-module.js +45 -45
- package/lib/browser/file-dialog/file-dialog-service.d.ts +32 -32
- package/lib/browser/file-dialog/file-dialog-service.js +101 -101
- package/lib/browser/file-dialog/file-dialog-tree-filters-renderer.d.ts +39 -39
- package/lib/browser/file-dialog/file-dialog-tree-filters-renderer.js +81 -81
- package/lib/browser/file-dialog/file-dialog-tree.d.ts +26 -26
- package/lib/browser/file-dialog/file-dialog-tree.js +83 -83
- package/lib/browser/file-dialog/file-dialog-widget.d.ts +15 -15
- package/lib/browser/file-dialog/file-dialog-widget.js +75 -75
- package/lib/browser/file-dialog/file-dialog.d.ts +129 -129
- package/lib/browser/file-dialog/file-dialog.js +351 -351
- package/lib/browser/file-dialog/index.d.ts +4 -4
- package/lib/browser/file-dialog/index.js +22 -22
- package/lib/browser/file-resource.d.ts +67 -67
- package/lib/browser/file-resource.js +369 -369
- package/lib/browser/file-selection.d.ts +14 -14
- package/lib/browser/file-selection.js +36 -36
- package/lib/browser/file-service.d.ts +425 -425
- package/lib/browser/file-service.js +1366 -1366
- package/lib/browser/file-tree/file-tree-container.d.ts +3 -3
- package/lib/browser/file-tree/file-tree-container.js +35 -35
- package/lib/browser/file-tree/file-tree-decorator-adapter.d.ts +30 -30
- package/lib/browser/file-tree/file-tree-decorator-adapter.js +169 -169
- package/lib/browser/file-tree/file-tree-label-provider.d.ts +12 -12
- package/lib/browser/file-tree/file-tree-label-provider.js +54 -54
- package/lib/browser/file-tree/file-tree-model.d.ts +37 -37
- package/lib/browser/file-tree/file-tree-model.js +217 -217
- package/lib/browser/file-tree/file-tree-widget.d.ts +44 -44
- package/lib/browser/file-tree/file-tree-widget.js +317 -317
- package/lib/browser/file-tree/file-tree.d.ts +46 -46
- package/lib/browser/file-tree/file-tree.js +176 -176
- package/lib/browser/file-tree/index.d.ts +6 -6
- package/lib/browser/file-tree/index.js +24 -24
- package/lib/browser/file-upload-service.d.ts +109 -109
- package/lib/browser/file-upload-service.js +434 -434
- package/lib/browser/filesystem-frontend-contribution.d.ts +74 -74
- package/lib/browser/filesystem-frontend-contribution.js +356 -356
- package/lib/browser/filesystem-frontend-module.d.ts +5 -5
- package/lib/browser/filesystem-frontend-module.js +64 -64
- package/lib/browser/filesystem-preferences.d.ts +29 -29
- package/lib/browser/filesystem-preferences.js +110 -110
- package/lib/browser/filesystem-save-resource-service.d.ts +29 -29
- package/lib/browser/filesystem-save-resource-service.js +135 -135
- package/lib/browser/filesystem-watcher-error-handler.d.ts +10 -10
- package/lib/browser/filesystem-watcher-error-handler.js +61 -61
- package/lib/browser/index.d.ts +5 -5
- package/lib/browser/index.js +23 -23
- package/lib/browser/location/index.d.ts +2 -2
- package/lib/browser/location/index.js +20 -20
- package/lib/browser/location/location-renderer.d.ts +100 -100
- package/lib/browser/location/location-renderer.js +343 -343
- package/lib/browser/location/location-service.d.ts +5 -5
- package/lib/browser/location/location-service.js +17 -17
- package/lib/browser/remote-file-service-contribution.d.ts +6 -6
- package/lib/browser/remote-file-service-contribution.js +39 -39
- package/lib/browser-only/browser-only-filesystem-frontend-module.d.ts +3 -3
- package/lib/browser-only/browser-only-filesystem-frontend-module.js +40 -40
- package/lib/browser-only/browser-only-filesystem-provider-server.d.ts +11 -11
- package/lib/browser-only/browser-only-filesystem-provider-server.js +39 -39
- package/lib/browser-only/browserfs-filesystem-initialization.d.ts +12 -12
- package/lib/browser-only/browserfs-filesystem-initialization.js +54 -54
- package/lib/browser-only/browserfs-filesystem-provider.d.ts +45 -45
- package/lib/browser-only/browserfs-filesystem-provider.js +439 -439
- package/lib/common/delegating-file-system-provider.d.ts +76 -76
- package/lib/common/delegating-file-system-provider.js +168 -168
- package/lib/common/download/file-download-data.d.ts +6 -6
- package/lib/common/download/file-download-data.js +26 -26
- package/lib/common/file-upload.d.ts +1 -1
- package/lib/common/file-upload.js +19 -19
- package/lib/common/files.d.ts +659 -659
- package/lib/common/files.js +355 -355
- package/lib/common/files.spec.d.ts +1 -1
- package/lib/common/files.spec.js +51 -51
- package/lib/common/filesystem-utils.d.ts +14 -14
- package/lib/common/filesystem-utils.js +63 -63
- package/lib/common/filesystem-utils.spec.d.ts +1 -1
- package/lib/common/filesystem-utils.spec.js +378 -378
- package/lib/common/filesystem-watcher-protocol.d.ts +71 -71
- package/lib/common/filesystem-watcher-protocol.js +20 -20
- package/lib/common/filesystem.d.ts +22 -22
- package/lib/common/filesystem.js +42 -42
- package/lib/common/index.d.ts +2 -2
- package/lib/common/index.js +20 -20
- package/lib/common/io.d.ts +19 -19
- package/lib/common/io.js +110 -110
- package/lib/common/remote-file-system-provider.d.ts +173 -173
- package/lib/common/remote-file-system-provider.js +435 -435
- package/lib/electron-browser/file-dialog/electron-file-dialog-module.d.ts +3 -3
- package/lib/electron-browser/file-dialog/electron-file-dialog-module.js +24 -24
- package/lib/electron-browser/file-dialog/electron-file-dialog-service.d.ts +19 -19
- package/lib/electron-browser/file-dialog/electron-file-dialog-service.js +148 -148
- package/lib/electron-browser/preload.d.ts +1 -1
- package/lib/electron-browser/preload.js +30 -30
- package/lib/electron-common/electron-api.d.ts +34 -34
- package/lib/electron-common/electron-api.js +20 -20
- package/lib/electron-main/electron-api-main.d.ts +5 -5
- package/lib/electron-main/electron-api-main.js +73 -73
- package/lib/electron-main/electron-main-module.d.ts +3 -3
- package/lib/electron-main/electron-main-module.js +24 -24
- package/lib/node/disk-file-system-provider.d.ts +72 -72
- package/lib/node/disk-file-system-provider.js +787 -787
- package/lib/node/disk-file-system-provider.spec.d.ts +1 -1
- package/lib/node/disk-file-system-provider.spec.js +122 -122
- package/lib/node/download/directory-archiver.d.ts +9 -9
- package/lib/node/download/directory-archiver.js +127 -127
- package/lib/node/download/directory-archiver.spec.d.ts +1 -1
- package/lib/node/download/directory-archiver.spec.js +97 -97
- package/lib/node/download/file-download-backend-module.d.ts +3 -3
- package/lib/node/download/file-download-backend-module.js +32 -32
- package/lib/node/download/file-download-cache.d.ts +21 -21
- package/lib/node/download/file-download-cache.js +82 -82
- package/lib/node/download/file-download-endpoint.d.ts +11 -11
- package/lib/node/download/file-download-endpoint.js +67 -67
- package/lib/node/download/file-download-handler.d.ts +50 -50
- package/lib/node/download/file-download-handler.js +307 -307
- package/lib/node/download/test/mock-directory-archiver.d.ts +7 -7
- package/lib/node/download/test/mock-directory-archiver.js +29 -29
- package/lib/node/file-change-collection.d.ts +22 -22
- package/lib/node/file-change-collection.js +77 -77
- package/lib/node/file-change-collection.spec.d.ts +1 -1
- package/lib/node/file-change-collection.spec.js +90 -90
- package/lib/node/filesystem-backend-module.d.ts +26 -26
- package/lib/node/filesystem-backend-module.js +120 -120
- package/lib/node/filesystem-watcher-client.d.ts +23 -23
- package/lib/node/filesystem-watcher-client.js +75 -75
- package/lib/node/filesystem-watcher-dispatcher.d.ts +23 -23
- package/lib/node/filesystem-watcher-dispatcher.js +80 -80
- package/lib/node/node-file-upload-service.d.ts +16 -16
- package/lib/node/node-file-upload-service.js +79 -79
- package/lib/node/nsfw-watcher/index.d.ts +3 -3
- package/lib/node/nsfw-watcher/index.js +39 -39
- package/lib/node/nsfw-watcher/nsfw-filesystem-service.d.ts +191 -191
- package/lib/node/nsfw-watcher/nsfw-filesystem-service.js +405 -405
- package/lib/node/nsfw-watcher/nsfw-filesystem-watcher.spec.d.ts +1 -1
- package/lib/node/nsfw-watcher/nsfw-filesystem-watcher.spec.js +151 -151
- package/lib/node/nsfw-watcher/nsfw-options.d.ts +6 -6
- package/lib/node/nsfw-watcher/nsfw-options.js +22 -22
- package/package.json +4 -4
- package/src/browser/breadcrumbs/filepath-breadcrumb.ts +43 -43
- package/src/browser/breadcrumbs/filepath-breadcrumbs-container.ts +65 -65
- package/src/browser/breadcrumbs/filepath-breadcrumbs-contribution.ts +129 -129
- package/src/browser/download/file-download-command-contribution.ts +83 -83
- package/src/browser/download/file-download-frontend-module.ts +25 -25
- package/src/browser/download/file-download-service.ts +179 -179
- package/src/browser/file-dialog/file-dialog-container.ts +67 -67
- package/src/browser/file-dialog/file-dialog-hidden-files-renderer.tsx +59 -59
- package/src/browser/file-dialog/file-dialog-model.ts +96 -96
- package/src/browser/file-dialog/file-dialog-module.ts +44 -44
- package/src/browser/file-dialog/file-dialog-service.ts +99 -99
- package/src/browser/file-dialog/file-dialog-tree-filters-renderer.tsx +100 -100
- package/src/browser/file-dialog/file-dialog-tree.ts +89 -89
- package/src/browser/file-dialog/file-dialog-widget.ts +75 -75
- package/src/browser/file-dialog/file-dialog.ts +434 -434
- package/src/browser/file-dialog/index.ts +20 -20
- package/src/browser/file-resource.ts +390 -390
- package/src/browser/file-selection.ts +44 -44
- package/src/browser/file-service.ts +1841 -1841
- package/src/browser/file-tree/file-tree-container.ts +36 -36
- package/src/browser/file-tree/file-tree-decorator-adapter.ts +159 -159
- package/src/browser/file-tree/file-tree-label-provider.ts +53 -53
- package/src/browser/file-tree/file-tree-model.ts +212 -212
- package/src/browser/file-tree/file-tree-widget.tsx +327 -327
- package/src/browser/file-tree/file-tree.ts +183 -183
- package/src/browser/file-tree/index.ts +22 -22
- package/src/browser/file-upload-service.ts +539 -539
- package/src/browser/filesystem-frontend-contribution.ts +381 -381
- package/src/browser/filesystem-frontend-module.ts +77 -77
- package/src/browser/filesystem-preferences.ts +139 -139
- package/src/browser/filesystem-save-resource-service.ts +125 -125
- package/src/browser/filesystem-watcher-error-handler.ts +60 -60
- package/src/browser/index.ts +21 -21
- package/src/browser/location/index.ts +18 -18
- package/src/browser/location/location-renderer.tsx +404 -404
- package/src/browser/location/location-service.ts +22 -22
- package/src/browser/remote-file-service-contribution.ts +38 -38
- package/src/browser/style/file-dialog.css +208 -208
- package/src/browser/style/file-icons.css +64 -64
- package/src/browser/style/filepath-breadcrumbs.css +20 -20
- package/src/browser/style/index.css +36 -36
- package/src/browser-only/browser-only-filesystem-frontend-module.ts +38 -38
- package/src/browser-only/browser-only-filesystem-provider-server.ts +32 -32
- package/src/browser-only/browserfs-filesystem-initialization.ts +61 -61
- package/src/browser-only/browserfs-filesystem-provider.ts +462 -462
- package/src/common/delegating-file-system-provider.ts +226 -226
- package/src/common/download/README.md +30 -30
- package/src/common/download/file-download-data.ts +27 -27
- package/src/common/file-upload.ts +17 -17
- package/src/common/files.spec.ts +51 -51
- package/src/common/files.ts +996 -996
- package/src/common/filesystem-utils.spec.ts +411 -411
- package/src/common/filesystem-utils.ts +64 -64
- package/src/common/filesystem-watcher-protocol.ts +96 -96
- package/src/common/filesystem.ts +43 -43
- package/src/common/index.ts +18 -18
- package/src/common/io.ts +150 -150
- package/src/common/remote-file-system-provider.ts +549 -549
- package/src/electron-browser/file-dialog/electron-file-dialog-module.ts +24 -24
- package/src/electron-browser/file-dialog/electron-file-dialog-service.ts +165 -165
- package/src/electron-browser/preload.ts +31 -31
- package/src/electron-common/electron-api.ts +55 -55
- package/src/electron-main/electron-api-main.ts +78 -78
- package/src/electron-main/electron-main-module.ts +23 -23
- package/src/node/disk-file-system-provider.spec.ts +142 -142
- package/src/node/disk-file-system-provider.ts +915 -915
- package/src/node/download/directory-archiver.spec.ts +104 -104
- package/src/node/download/directory-archiver.ts +126 -126
- package/src/node/download/file-download-backend-module.ts +32 -32
- package/src/node/download/file-download-cache.ts +88 -88
- package/src/node/download/file-download-endpoint.ts +63 -63
- package/src/node/download/file-download-handler.ts +304 -304
- package/src/node/download/test/mock-directory-archiver.ts +30 -30
- package/src/node/file-change-collection.spec.ts +110 -110
- package/src/node/file-change-collection.ts +78 -78
- package/src/node/filesystem-backend-module.ts +140 -140
- package/src/node/filesystem-watcher-client.ts +72 -72
- package/src/node/filesystem-watcher-dispatcher.ts +82 -82
- package/src/node/node-file-upload-service.ts +80 -80
- package/src/node/nsfw-watcher/index.ts +45 -45
- package/src/node/nsfw-watcher/nsfw-filesystem-service.ts +481 -481
- package/src/node/nsfw-watcher/nsfw-filesystem-watcher.spec.ts +182 -182
- package/src/node/nsfw-watcher/nsfw-options.ts +23 -23
- package/src/typings/dom.webkit.d.ts +77 -77
- package/src/typings/mv/index.d.ts +21 -21
- package/src/typings/nsfw/index.d.ts +18 -18
- package/src/typings/trash/index.d.ts +20 -20
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export {};
|
|
1
|
+
export {};
|
|
2
2
|
//# sourceMappingURL=disk-file-system-provider.spec.d.ts.map
|
|
@@ -1,123 +1,123 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
// *****************************************************************************
|
|
3
|
-
// Copyright (C) 2023 Arduino SA 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
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
-
const disposable_1 = require("@theia/core/lib/common/disposable");
|
|
19
|
-
const encoding_service_1 = require("@theia/core/lib/common/encoding-service");
|
|
20
|
-
const logger_1 = require("@theia/core/lib/common/logger");
|
|
21
|
-
const mock_logger_1 = require("@theia/core/lib/common/test/mock-logger");
|
|
22
|
-
const file_uri_1 = require("@theia/core/lib/common/file-uri");
|
|
23
|
-
const ipc_connection_provider_1 = require("@theia/core/lib/node/messaging/ipc-connection-provider");
|
|
24
|
-
const inversify_1 = require("@theia/core/shared/inversify");
|
|
25
|
-
const assert_1 = require("assert");
|
|
26
|
-
const fs_1 = require("fs");
|
|
27
|
-
const path_1 = require("path");
|
|
28
|
-
const temp = require("temp");
|
|
29
|
-
const uuid_1 = require("@theia/core/lib/common/uuid");
|
|
30
|
-
const files_1 = require("../common/files");
|
|
31
|
-
const disk_file_system_provider_1 = require("./disk-file-system-provider");
|
|
32
|
-
const filesystem_backend_module_1 = require("./filesystem-backend-module");
|
|
33
|
-
const tracked = temp.track();
|
|
34
|
-
describe('disk-file-system-provider', () => {
|
|
35
|
-
let toDisposeAfter;
|
|
36
|
-
let fsProvider;
|
|
37
|
-
before(() => {
|
|
38
|
-
fsProvider = createContainer().get(disk_file_system_provider_1.DiskFileSystemProvider);
|
|
39
|
-
toDisposeAfter = new disposable_1.DisposableCollection(fsProvider, disposable_1.Disposable.create(() => tracked.cleanupSync()));
|
|
40
|
-
});
|
|
41
|
-
after(() => {
|
|
42
|
-
toDisposeAfter.dispose();
|
|
43
|
-
});
|
|
44
|
-
describe('stat', () => {
|
|
45
|
-
it("should omit the 'permissions' property of the stat if the file can be both read and write", async () => {
|
|
46
|
-
const tempDirPath = tracked.mkdirSync();
|
|
47
|
-
const tempFilePath = (0, path_1.join)(tempDirPath, `${(0, uuid_1.generateUuid)()}.txt`);
|
|
48
|
-
await fs_1.promises.writeFile(tempFilePath, 'some content', { encoding: 'utf8' });
|
|
49
|
-
let content = await fs_1.promises.readFile(tempFilePath, { encoding: 'utf8' });
|
|
50
|
-
(0, assert_1.equal)(content, 'some content');
|
|
51
|
-
await fs_1.promises.writeFile(tempFilePath, 'other content', { encoding: 'utf8' });
|
|
52
|
-
content = await fs_1.promises.readFile(tempFilePath, { encoding: 'utf8' });
|
|
53
|
-
(0, assert_1.equal)(content, 'other content');
|
|
54
|
-
const stat = await fsProvider.stat(file_uri_1.FileUri.create(tempFilePath));
|
|
55
|
-
(0, assert_1.equal)(stat.permissions, undefined);
|
|
56
|
-
});
|
|
57
|
-
it("should set the 'permissions' property to `Readonly` if the file can be read but not write", async () => {
|
|
58
|
-
const tempDirPath = tracked.mkdirSync();
|
|
59
|
-
const tempFilePath = (0, path_1.join)(tempDirPath, `${(0, uuid_1.generateUuid)()}.txt`);
|
|
60
|
-
await fs_1.promises.writeFile(tempFilePath, 'readonly content', {
|
|
61
|
-
encoding: 'utf8',
|
|
62
|
-
});
|
|
63
|
-
await fs_1.promises.chmod(tempFilePath, '444'); // read-only for owner/group/world
|
|
64
|
-
try {
|
|
65
|
-
await fsProvider.writeFile(file_uri_1.FileUri.create(tempFilePath), new Uint8Array(), { create: false, overwrite: true });
|
|
66
|
-
(0, assert_1.fail)('Expected an EACCES error for readonly (chmod 444) files');
|
|
67
|
-
}
|
|
68
|
-
catch (err) {
|
|
69
|
-
(0, assert_1.equal)(err instanceof files_1.FileSystemProviderError, true);
|
|
70
|
-
(0, assert_1.equal)(err.code, files_1.FileSystemProviderErrorCode.NoPermissions);
|
|
71
|
-
}
|
|
72
|
-
const content = await fs_1.promises.readFile(tempFilePath, { encoding: 'utf8' });
|
|
73
|
-
(0, assert_1.equal)(content, 'readonly content');
|
|
74
|
-
const stat = await fsProvider.stat(file_uri_1.FileUri.create(tempFilePath));
|
|
75
|
-
(0, assert_1.equal)(stat.permissions, files_1.FilePermission.Readonly);
|
|
76
|
-
});
|
|
77
|
-
});
|
|
78
|
-
describe('delete', () => {
|
|
79
|
-
it('delete is able to delete folder', async () => {
|
|
80
|
-
const tempDirPath = tracked.mkdirSync();
|
|
81
|
-
const testFolder = (0, path_1.join)(tempDirPath, 'test');
|
|
82
|
-
const folderUri = file_uri_1.FileUri.create(testFolder);
|
|
83
|
-
for (const recursive of [true, false]) {
|
|
84
|
-
// Note: useTrash = true fails on Linux
|
|
85
|
-
const useTrash = false;
|
|
86
|
-
if ((fsProvider.capabilities & 16777216 /* Access */) === 0 && useTrash) {
|
|
87
|
-
continue;
|
|
88
|
-
}
|
|
89
|
-
await fsProvider.mkdir(folderUri);
|
|
90
|
-
if (recursive) {
|
|
91
|
-
await fsProvider.writeFile(file_uri_1.FileUri.create((0, path_1.join)(testFolder, 'test.file')), Buffer.from('test'), { overwrite: false, create: true });
|
|
92
|
-
await fsProvider.mkdir(file_uri_1.FileUri.create((0, path_1.join)(testFolder, 'subFolder')));
|
|
93
|
-
}
|
|
94
|
-
await fsProvider.delete(folderUri, { recursive, useTrash });
|
|
95
|
-
}
|
|
96
|
-
});
|
|
97
|
-
it('delete is able to delete file', async () => {
|
|
98
|
-
const tempDirPath = tracked.mkdirSync();
|
|
99
|
-
const testFile = (0, path_1.join)(tempDirPath, 'test.file');
|
|
100
|
-
const testFileUri = file_uri_1.FileUri.create(testFile);
|
|
101
|
-
for (const recursive of [true, false]) {
|
|
102
|
-
for (const useTrash of [true, false]) {
|
|
103
|
-
await fsProvider.writeFile(testFileUri, Buffer.from('test'), { overwrite: false, create: true });
|
|
104
|
-
await fsProvider.delete(testFileUri, { recursive, useTrash });
|
|
105
|
-
}
|
|
106
|
-
}
|
|
107
|
-
});
|
|
108
|
-
});
|
|
109
|
-
function createContainer() {
|
|
110
|
-
const container = new inversify_1.Container({ defaultScope: 'Singleton' });
|
|
111
|
-
const module = new inversify_1.ContainerModule(bind => {
|
|
112
|
-
bind(disk_file_system_provider_1.DiskFileSystemProvider).toSelf().inSingletonScope();
|
|
113
|
-
bind(encoding_service_1.EncodingService).toSelf().inSingletonScope();
|
|
114
|
-
(0, filesystem_backend_module_1.bindFileSystemWatcherServer)(bind);
|
|
115
|
-
bind(mock_logger_1.MockLogger).toSelf().inSingletonScope();
|
|
116
|
-
bind(logger_1.ILogger).toService(mock_logger_1.MockLogger);
|
|
117
|
-
bind(ipc_connection_provider_1.IPCConnectionProvider).toSelf().inSingletonScope();
|
|
118
|
-
});
|
|
119
|
-
container.load(module);
|
|
120
|
-
return container;
|
|
121
|
-
}
|
|
122
|
-
});
|
|
1
|
+
"use strict";
|
|
2
|
+
// *****************************************************************************
|
|
3
|
+
// Copyright (C) 2023 Arduino SA 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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
+
const disposable_1 = require("@theia/core/lib/common/disposable");
|
|
19
|
+
const encoding_service_1 = require("@theia/core/lib/common/encoding-service");
|
|
20
|
+
const logger_1 = require("@theia/core/lib/common/logger");
|
|
21
|
+
const mock_logger_1 = require("@theia/core/lib/common/test/mock-logger");
|
|
22
|
+
const file_uri_1 = require("@theia/core/lib/common/file-uri");
|
|
23
|
+
const ipc_connection_provider_1 = require("@theia/core/lib/node/messaging/ipc-connection-provider");
|
|
24
|
+
const inversify_1 = require("@theia/core/shared/inversify");
|
|
25
|
+
const assert_1 = require("assert");
|
|
26
|
+
const fs_1 = require("fs");
|
|
27
|
+
const path_1 = require("path");
|
|
28
|
+
const temp = require("temp");
|
|
29
|
+
const uuid_1 = require("@theia/core/lib/common/uuid");
|
|
30
|
+
const files_1 = require("../common/files");
|
|
31
|
+
const disk_file_system_provider_1 = require("./disk-file-system-provider");
|
|
32
|
+
const filesystem_backend_module_1 = require("./filesystem-backend-module");
|
|
33
|
+
const tracked = temp.track();
|
|
34
|
+
describe('disk-file-system-provider', () => {
|
|
35
|
+
let toDisposeAfter;
|
|
36
|
+
let fsProvider;
|
|
37
|
+
before(() => {
|
|
38
|
+
fsProvider = createContainer().get(disk_file_system_provider_1.DiskFileSystemProvider);
|
|
39
|
+
toDisposeAfter = new disposable_1.DisposableCollection(fsProvider, disposable_1.Disposable.create(() => tracked.cleanupSync()));
|
|
40
|
+
});
|
|
41
|
+
after(() => {
|
|
42
|
+
toDisposeAfter.dispose();
|
|
43
|
+
});
|
|
44
|
+
describe('stat', () => {
|
|
45
|
+
it("should omit the 'permissions' property of the stat if the file can be both read and write", async () => {
|
|
46
|
+
const tempDirPath = tracked.mkdirSync();
|
|
47
|
+
const tempFilePath = (0, path_1.join)(tempDirPath, `${(0, uuid_1.generateUuid)()}.txt`);
|
|
48
|
+
await fs_1.promises.writeFile(tempFilePath, 'some content', { encoding: 'utf8' });
|
|
49
|
+
let content = await fs_1.promises.readFile(tempFilePath, { encoding: 'utf8' });
|
|
50
|
+
(0, assert_1.equal)(content, 'some content');
|
|
51
|
+
await fs_1.promises.writeFile(tempFilePath, 'other content', { encoding: 'utf8' });
|
|
52
|
+
content = await fs_1.promises.readFile(tempFilePath, { encoding: 'utf8' });
|
|
53
|
+
(0, assert_1.equal)(content, 'other content');
|
|
54
|
+
const stat = await fsProvider.stat(file_uri_1.FileUri.create(tempFilePath));
|
|
55
|
+
(0, assert_1.equal)(stat.permissions, undefined);
|
|
56
|
+
});
|
|
57
|
+
it("should set the 'permissions' property to `Readonly` if the file can be read but not write", async () => {
|
|
58
|
+
const tempDirPath = tracked.mkdirSync();
|
|
59
|
+
const tempFilePath = (0, path_1.join)(tempDirPath, `${(0, uuid_1.generateUuid)()}.txt`);
|
|
60
|
+
await fs_1.promises.writeFile(tempFilePath, 'readonly content', {
|
|
61
|
+
encoding: 'utf8',
|
|
62
|
+
});
|
|
63
|
+
await fs_1.promises.chmod(tempFilePath, '444'); // read-only for owner/group/world
|
|
64
|
+
try {
|
|
65
|
+
await fsProvider.writeFile(file_uri_1.FileUri.create(tempFilePath), new Uint8Array(), { create: false, overwrite: true });
|
|
66
|
+
(0, assert_1.fail)('Expected an EACCES error for readonly (chmod 444) files');
|
|
67
|
+
}
|
|
68
|
+
catch (err) {
|
|
69
|
+
(0, assert_1.equal)(err instanceof files_1.FileSystemProviderError, true);
|
|
70
|
+
(0, assert_1.equal)(err.code, files_1.FileSystemProviderErrorCode.NoPermissions);
|
|
71
|
+
}
|
|
72
|
+
const content = await fs_1.promises.readFile(tempFilePath, { encoding: 'utf8' });
|
|
73
|
+
(0, assert_1.equal)(content, 'readonly content');
|
|
74
|
+
const stat = await fsProvider.stat(file_uri_1.FileUri.create(tempFilePath));
|
|
75
|
+
(0, assert_1.equal)(stat.permissions, files_1.FilePermission.Readonly);
|
|
76
|
+
});
|
|
77
|
+
});
|
|
78
|
+
describe('delete', () => {
|
|
79
|
+
it('delete is able to delete folder', async () => {
|
|
80
|
+
const tempDirPath = tracked.mkdirSync();
|
|
81
|
+
const testFolder = (0, path_1.join)(tempDirPath, 'test');
|
|
82
|
+
const folderUri = file_uri_1.FileUri.create(testFolder);
|
|
83
|
+
for (const recursive of [true, false]) {
|
|
84
|
+
// Note: useTrash = true fails on Linux
|
|
85
|
+
const useTrash = false;
|
|
86
|
+
if ((fsProvider.capabilities & 16777216 /* Access */) === 0 && useTrash) {
|
|
87
|
+
continue;
|
|
88
|
+
}
|
|
89
|
+
await fsProvider.mkdir(folderUri);
|
|
90
|
+
if (recursive) {
|
|
91
|
+
await fsProvider.writeFile(file_uri_1.FileUri.create((0, path_1.join)(testFolder, 'test.file')), Buffer.from('test'), { overwrite: false, create: true });
|
|
92
|
+
await fsProvider.mkdir(file_uri_1.FileUri.create((0, path_1.join)(testFolder, 'subFolder')));
|
|
93
|
+
}
|
|
94
|
+
await fsProvider.delete(folderUri, { recursive, useTrash });
|
|
95
|
+
}
|
|
96
|
+
});
|
|
97
|
+
it('delete is able to delete file', async () => {
|
|
98
|
+
const tempDirPath = tracked.mkdirSync();
|
|
99
|
+
const testFile = (0, path_1.join)(tempDirPath, 'test.file');
|
|
100
|
+
const testFileUri = file_uri_1.FileUri.create(testFile);
|
|
101
|
+
for (const recursive of [true, false]) {
|
|
102
|
+
for (const useTrash of [true, false]) {
|
|
103
|
+
await fsProvider.writeFile(testFileUri, Buffer.from('test'), { overwrite: false, create: true });
|
|
104
|
+
await fsProvider.delete(testFileUri, { recursive, useTrash });
|
|
105
|
+
}
|
|
106
|
+
}
|
|
107
|
+
});
|
|
108
|
+
});
|
|
109
|
+
function createContainer() {
|
|
110
|
+
const container = new inversify_1.Container({ defaultScope: 'Singleton' });
|
|
111
|
+
const module = new inversify_1.ContainerModule(bind => {
|
|
112
|
+
bind(disk_file_system_provider_1.DiskFileSystemProvider).toSelf().inSingletonScope();
|
|
113
|
+
bind(encoding_service_1.EncodingService).toSelf().inSingletonScope();
|
|
114
|
+
(0, filesystem_backend_module_1.bindFileSystemWatcherServer)(bind);
|
|
115
|
+
bind(mock_logger_1.MockLogger).toSelf().inSingletonScope();
|
|
116
|
+
bind(logger_1.ILogger).toService(mock_logger_1.MockLogger);
|
|
117
|
+
bind(ipc_connection_provider_1.IPCConnectionProvider).toSelf().inSingletonScope();
|
|
118
|
+
});
|
|
119
|
+
container.load(module);
|
|
120
|
+
return container;
|
|
121
|
+
}
|
|
122
|
+
});
|
|
123
123
|
//# sourceMappingURL=disk-file-system-provider.spec.js.map
|
|
@@ -1,10 +1,10 @@
|
|
|
1
|
-
import URI from '@theia/core/lib/common/uri';
|
|
2
|
-
export declare class DirectoryArchiver {
|
|
3
|
-
archive(inputPath: string, outputPath: string, entries?: string[]): Promise<void>;
|
|
4
|
-
findCommonParents(uris: URI[]): Promise<Map<string, string[]>>;
|
|
5
|
-
protected closestCommonParentUri(left: URI, right: URI): URI | undefined;
|
|
6
|
-
protected isDir(uri: URI): Promise<boolean>;
|
|
7
|
-
protected equal(left: URI | URI[], right: URI | URI[]): boolean;
|
|
8
|
-
protected toUriString(uri: URI): string;
|
|
9
|
-
}
|
|
1
|
+
import URI from '@theia/core/lib/common/uri';
|
|
2
|
+
export declare class DirectoryArchiver {
|
|
3
|
+
archive(inputPath: string, outputPath: string, entries?: string[]): Promise<void>;
|
|
4
|
+
findCommonParents(uris: URI[]): Promise<Map<string, string[]>>;
|
|
5
|
+
protected closestCommonParentUri(left: URI, right: URI): URI | undefined;
|
|
6
|
+
protected isDir(uri: URI): Promise<boolean>;
|
|
7
|
+
protected equal(left: URI | URI[], right: URI | URI[]): boolean;
|
|
8
|
+
protected toUriString(uri: URI): string;
|
|
9
|
+
}
|
|
10
10
|
//# sourceMappingURL=directory-archiver.d.ts.map
|
|
@@ -1,128 +1,128 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
// *****************************************************************************
|
|
3
|
-
// Copyright (C) 2018 TypeFox 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
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
-
exports.DirectoryArchiver = void 0;
|
|
19
|
-
const tslib_1 = require("tslib");
|
|
20
|
-
const inversify_1 = require("@theia/core/shared/inversify");
|
|
21
|
-
const fs = require("@theia/core/shared/fs-extra");
|
|
22
|
-
const tar_fs_1 = require("tar-fs");
|
|
23
|
-
const uri_1 = require("@theia/core/lib/common/uri");
|
|
24
|
-
const file_uri_1 = require("@theia/core/lib/common/file-uri");
|
|
25
|
-
let DirectoryArchiver = class DirectoryArchiver {
|
|
26
|
-
async archive(inputPath, outputPath, entries) {
|
|
27
|
-
return new Promise(async (resolve, reject) => {
|
|
28
|
-
(0, tar_fs_1.pack)(inputPath, { entries }).pipe(fs.createWriteStream(outputPath)).on('finish', () => resolve()).on('error', e => reject(e));
|
|
29
|
-
});
|
|
30
|
-
}
|
|
31
|
-
async findCommonParents(uris) {
|
|
32
|
-
const map = new Map();
|
|
33
|
-
for (const uri of uris) {
|
|
34
|
-
// 1. Get the container if not the URI is not a directory.
|
|
35
|
-
const containerUri = (await this.isDir(uri)) ? uri : uri.parent;
|
|
36
|
-
let containerUriStr = this.toUriString(containerUri);
|
|
37
|
-
// 2. If the container already registered, just append the current URI to it.
|
|
38
|
-
if (map.has(containerUriStr)) {
|
|
39
|
-
map.set(containerUriStr, [...map.get(containerUriStr), this.toUriString(uri)]);
|
|
40
|
-
}
|
|
41
|
-
else {
|
|
42
|
-
// 3. Try to find the longest container URI that we can use.
|
|
43
|
-
// When we have `/A/B/` and `/A/C` and a file `A/B/C/D.txt` then we need to find `/A/B`. The longest URIs come first.
|
|
44
|
-
for (const knownContainerUri of Array.from(map.keys()).sort((left, right) => right.length - left.length)) {
|
|
45
|
-
if (uri.toString().startsWith(knownContainerUri)) {
|
|
46
|
-
containerUriStr = knownContainerUri;
|
|
47
|
-
break;
|
|
48
|
-
}
|
|
49
|
-
}
|
|
50
|
-
const entries = map.get(containerUriStr) || [];
|
|
51
|
-
entries.push(this.toUriString(uri));
|
|
52
|
-
map.set(containerUriStr, entries);
|
|
53
|
-
}
|
|
54
|
-
// 4. Collapse the hierarchy by finding the closest common parents for the entries, if any.
|
|
55
|
-
let collapsed = false;
|
|
56
|
-
collapseLoop: while (!collapsed) {
|
|
57
|
-
const knownContainerUris = Array.from(map.keys()).sort((left, right) => right.length - left.length);
|
|
58
|
-
if (knownContainerUris.length > 1) {
|
|
59
|
-
for (let i = 0; i < knownContainerUris.length; i++) {
|
|
60
|
-
for (let j = i + 1; j < knownContainerUris.length; j++) {
|
|
61
|
-
const left = knownContainerUris[i];
|
|
62
|
-
const right = knownContainerUris[j];
|
|
63
|
-
const commonParent = this.closestCommonParentUri(new uri_1.default(left), new uri_1.default(right));
|
|
64
|
-
if (commonParent && !commonParent.path.isRoot) {
|
|
65
|
-
const leftEntries = map.get(left) || [];
|
|
66
|
-
const rightEntries = map.get(right) || [];
|
|
67
|
-
map.delete(left);
|
|
68
|
-
map.delete(right);
|
|
69
|
-
map.set(this.toUriString(commonParent), [...leftEntries, ...rightEntries]);
|
|
70
|
-
break collapseLoop;
|
|
71
|
-
}
|
|
72
|
-
}
|
|
73
|
-
}
|
|
74
|
-
}
|
|
75
|
-
collapsed = true;
|
|
76
|
-
}
|
|
77
|
-
}
|
|
78
|
-
return map;
|
|
79
|
-
}
|
|
80
|
-
closestCommonParentUri(left, right) {
|
|
81
|
-
if (left.scheme !== right.scheme) {
|
|
82
|
-
return undefined;
|
|
83
|
-
}
|
|
84
|
-
const allLeft = left.allLocations;
|
|
85
|
-
const allRight = right.allLocations;
|
|
86
|
-
for (const leftUri of allLeft) {
|
|
87
|
-
for (const rightUri of allRight) {
|
|
88
|
-
if (this.equal(leftUri, rightUri)) {
|
|
89
|
-
return leftUri;
|
|
90
|
-
}
|
|
91
|
-
}
|
|
92
|
-
}
|
|
93
|
-
return undefined;
|
|
94
|
-
}
|
|
95
|
-
async isDir(uri) {
|
|
96
|
-
try {
|
|
97
|
-
const stat = await fs.stat(file_uri_1.FileUri.fsPath(uri));
|
|
98
|
-
return stat.isDirectory();
|
|
99
|
-
}
|
|
100
|
-
catch {
|
|
101
|
-
return false;
|
|
102
|
-
}
|
|
103
|
-
}
|
|
104
|
-
equal(left, right) {
|
|
105
|
-
if (Array.isArray(left) && Array.isArray(right)) {
|
|
106
|
-
if (left === right) {
|
|
107
|
-
return true;
|
|
108
|
-
}
|
|
109
|
-
if (left.length !== right.length) {
|
|
110
|
-
return false;
|
|
111
|
-
}
|
|
112
|
-
return left.map(this.toUriString).sort().toString() === right.map(this.toUriString).sort().toString();
|
|
113
|
-
}
|
|
114
|
-
else if (left instanceof uri_1.default && right instanceof uri_1.default) {
|
|
115
|
-
return this.toUriString(left) === this.toUriString(right);
|
|
116
|
-
}
|
|
117
|
-
return false;
|
|
118
|
-
}
|
|
119
|
-
toUriString(uri) {
|
|
120
|
-
const raw = uri.toString();
|
|
121
|
-
return raw.endsWith('/') ? raw.slice(0, -1) : raw;
|
|
122
|
-
}
|
|
123
|
-
};
|
|
124
|
-
DirectoryArchiver = (0, tslib_1.__decorate)([
|
|
125
|
-
(0, inversify_1.injectable)()
|
|
126
|
-
], DirectoryArchiver);
|
|
127
|
-
exports.DirectoryArchiver = DirectoryArchiver;
|
|
1
|
+
"use strict";
|
|
2
|
+
// *****************************************************************************
|
|
3
|
+
// Copyright (C) 2018 TypeFox 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
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
18
|
+
exports.DirectoryArchiver = void 0;
|
|
19
|
+
const tslib_1 = require("tslib");
|
|
20
|
+
const inversify_1 = require("@theia/core/shared/inversify");
|
|
21
|
+
const fs = require("@theia/core/shared/fs-extra");
|
|
22
|
+
const tar_fs_1 = require("tar-fs");
|
|
23
|
+
const uri_1 = require("@theia/core/lib/common/uri");
|
|
24
|
+
const file_uri_1 = require("@theia/core/lib/common/file-uri");
|
|
25
|
+
let DirectoryArchiver = class DirectoryArchiver {
|
|
26
|
+
async archive(inputPath, outputPath, entries) {
|
|
27
|
+
return new Promise(async (resolve, reject) => {
|
|
28
|
+
(0, tar_fs_1.pack)(inputPath, { entries }).pipe(fs.createWriteStream(outputPath)).on('finish', () => resolve()).on('error', e => reject(e));
|
|
29
|
+
});
|
|
30
|
+
}
|
|
31
|
+
async findCommonParents(uris) {
|
|
32
|
+
const map = new Map();
|
|
33
|
+
for (const uri of uris) {
|
|
34
|
+
// 1. Get the container if not the URI is not a directory.
|
|
35
|
+
const containerUri = (await this.isDir(uri)) ? uri : uri.parent;
|
|
36
|
+
let containerUriStr = this.toUriString(containerUri);
|
|
37
|
+
// 2. If the container already registered, just append the current URI to it.
|
|
38
|
+
if (map.has(containerUriStr)) {
|
|
39
|
+
map.set(containerUriStr, [...map.get(containerUriStr), this.toUriString(uri)]);
|
|
40
|
+
}
|
|
41
|
+
else {
|
|
42
|
+
// 3. Try to find the longest container URI that we can use.
|
|
43
|
+
// When we have `/A/B/` and `/A/C` and a file `A/B/C/D.txt` then we need to find `/A/B`. The longest URIs come first.
|
|
44
|
+
for (const knownContainerUri of Array.from(map.keys()).sort((left, right) => right.length - left.length)) {
|
|
45
|
+
if (uri.toString().startsWith(knownContainerUri)) {
|
|
46
|
+
containerUriStr = knownContainerUri;
|
|
47
|
+
break;
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
const entries = map.get(containerUriStr) || [];
|
|
51
|
+
entries.push(this.toUriString(uri));
|
|
52
|
+
map.set(containerUriStr, entries);
|
|
53
|
+
}
|
|
54
|
+
// 4. Collapse the hierarchy by finding the closest common parents for the entries, if any.
|
|
55
|
+
let collapsed = false;
|
|
56
|
+
collapseLoop: while (!collapsed) {
|
|
57
|
+
const knownContainerUris = Array.from(map.keys()).sort((left, right) => right.length - left.length);
|
|
58
|
+
if (knownContainerUris.length > 1) {
|
|
59
|
+
for (let i = 0; i < knownContainerUris.length; i++) {
|
|
60
|
+
for (let j = i + 1; j < knownContainerUris.length; j++) {
|
|
61
|
+
const left = knownContainerUris[i];
|
|
62
|
+
const right = knownContainerUris[j];
|
|
63
|
+
const commonParent = this.closestCommonParentUri(new uri_1.default(left), new uri_1.default(right));
|
|
64
|
+
if (commonParent && !commonParent.path.isRoot) {
|
|
65
|
+
const leftEntries = map.get(left) || [];
|
|
66
|
+
const rightEntries = map.get(right) || [];
|
|
67
|
+
map.delete(left);
|
|
68
|
+
map.delete(right);
|
|
69
|
+
map.set(this.toUriString(commonParent), [...leftEntries, ...rightEntries]);
|
|
70
|
+
break collapseLoop;
|
|
71
|
+
}
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
collapsed = true;
|
|
76
|
+
}
|
|
77
|
+
}
|
|
78
|
+
return map;
|
|
79
|
+
}
|
|
80
|
+
closestCommonParentUri(left, right) {
|
|
81
|
+
if (left.scheme !== right.scheme) {
|
|
82
|
+
return undefined;
|
|
83
|
+
}
|
|
84
|
+
const allLeft = left.allLocations;
|
|
85
|
+
const allRight = right.allLocations;
|
|
86
|
+
for (const leftUri of allLeft) {
|
|
87
|
+
for (const rightUri of allRight) {
|
|
88
|
+
if (this.equal(leftUri, rightUri)) {
|
|
89
|
+
return leftUri;
|
|
90
|
+
}
|
|
91
|
+
}
|
|
92
|
+
}
|
|
93
|
+
return undefined;
|
|
94
|
+
}
|
|
95
|
+
async isDir(uri) {
|
|
96
|
+
try {
|
|
97
|
+
const stat = await fs.stat(file_uri_1.FileUri.fsPath(uri));
|
|
98
|
+
return stat.isDirectory();
|
|
99
|
+
}
|
|
100
|
+
catch {
|
|
101
|
+
return false;
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
equal(left, right) {
|
|
105
|
+
if (Array.isArray(left) && Array.isArray(right)) {
|
|
106
|
+
if (left === right) {
|
|
107
|
+
return true;
|
|
108
|
+
}
|
|
109
|
+
if (left.length !== right.length) {
|
|
110
|
+
return false;
|
|
111
|
+
}
|
|
112
|
+
return left.map(this.toUriString).sort().toString() === right.map(this.toUriString).sort().toString();
|
|
113
|
+
}
|
|
114
|
+
else if (left instanceof uri_1.default && right instanceof uri_1.default) {
|
|
115
|
+
return this.toUriString(left) === this.toUriString(right);
|
|
116
|
+
}
|
|
117
|
+
return false;
|
|
118
|
+
}
|
|
119
|
+
toUriString(uri) {
|
|
120
|
+
const raw = uri.toString();
|
|
121
|
+
return raw.endsWith('/') ? raw.slice(0, -1) : raw;
|
|
122
|
+
}
|
|
123
|
+
};
|
|
124
|
+
DirectoryArchiver = (0, tslib_1.__decorate)([
|
|
125
|
+
(0, inversify_1.injectable)()
|
|
126
|
+
], DirectoryArchiver);
|
|
127
|
+
exports.DirectoryArchiver = DirectoryArchiver;
|
|
128
128
|
//# sourceMappingURL=directory-archiver.js.map
|
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
export {};
|
|
1
|
+
export {};
|
|
2
2
|
//# sourceMappingURL=directory-archiver.spec.d.ts.map
|