@theia/filesystem 1.53.0-next.55 → 1.53.0-next.64

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 (90) hide show
  1. package/README.md +30 -30
  2. package/package.json +3 -3
  3. package/src/browser/breadcrumbs/filepath-breadcrumb.ts +43 -43
  4. package/src/browser/breadcrumbs/filepath-breadcrumbs-container.ts +65 -65
  5. package/src/browser/breadcrumbs/filepath-breadcrumbs-contribution.ts +129 -129
  6. package/src/browser/download/file-download-command-contribution.ts +83 -83
  7. package/src/browser/download/file-download-frontend-module.ts +25 -25
  8. package/src/browser/download/file-download-service.ts +179 -179
  9. package/src/browser/file-dialog/file-dialog-container.ts +67 -67
  10. package/src/browser/file-dialog/file-dialog-hidden-files-renderer.tsx +59 -59
  11. package/src/browser/file-dialog/file-dialog-model.ts +96 -96
  12. package/src/browser/file-dialog/file-dialog-module.ts +44 -44
  13. package/src/browser/file-dialog/file-dialog-service.ts +99 -99
  14. package/src/browser/file-dialog/file-dialog-tree-filters-renderer.tsx +100 -100
  15. package/src/browser/file-dialog/file-dialog-tree.ts +89 -89
  16. package/src/browser/file-dialog/file-dialog-widget.ts +75 -75
  17. package/src/browser/file-dialog/file-dialog.ts +434 -434
  18. package/src/browser/file-dialog/index.ts +20 -20
  19. package/src/browser/file-resource.spec.ts +255 -255
  20. package/src/browser/file-resource.ts +402 -402
  21. package/src/browser/file-selection.ts +44 -44
  22. package/src/browser/file-service.ts +1845 -1845
  23. package/src/browser/file-tree/file-tree-container.ts +36 -36
  24. package/src/browser/file-tree/file-tree-decorator-adapter.ts +159 -159
  25. package/src/browser/file-tree/file-tree-label-provider.ts +53 -53
  26. package/src/browser/file-tree/file-tree-model.ts +212 -212
  27. package/src/browser/file-tree/file-tree-widget.tsx +327 -327
  28. package/src/browser/file-tree/file-tree.ts +183 -183
  29. package/src/browser/file-tree/index.ts +22 -22
  30. package/src/browser/file-upload-service.ts +547 -547
  31. package/src/browser/filesystem-frontend-contribution.ts +396 -396
  32. package/src/browser/filesystem-frontend-module.ts +77 -77
  33. package/src/browser/filesystem-preferences.ts +139 -139
  34. package/src/browser/filesystem-saveable-service.ts +138 -138
  35. package/src/browser/filesystem-watcher-error-handler.ts +60 -60
  36. package/src/browser/index.ts +21 -21
  37. package/src/browser/location/index.ts +18 -18
  38. package/src/browser/location/location-renderer.tsx +406 -406
  39. package/src/browser/location/location-service.ts +22 -22
  40. package/src/browser/remote-file-service-contribution.ts +38 -38
  41. package/src/browser/style/file-dialog.css +208 -208
  42. package/src/browser/style/file-icons.css +64 -64
  43. package/src/browser/style/filepath-breadcrumbs.css +20 -20
  44. package/src/browser/style/index.css +36 -36
  45. package/src/browser-only/browser-only-filesystem-frontend-module.ts +38 -38
  46. package/src/browser-only/browser-only-filesystem-provider-server.ts +32 -32
  47. package/src/browser-only/browserfs-filesystem-initialization.ts +61 -61
  48. package/src/browser-only/browserfs-filesystem-provider.ts +462 -462
  49. package/src/common/delegating-file-system-provider.ts +226 -226
  50. package/src/common/download/README.md +30 -30
  51. package/src/common/download/file-download-data.ts +27 -27
  52. package/src/common/file-upload.ts +17 -17
  53. package/src/common/files.spec.ts +51 -51
  54. package/src/common/files.ts +997 -997
  55. package/src/common/filesystem-utils.spec.ts +411 -411
  56. package/src/common/filesystem-utils.ts +64 -64
  57. package/src/common/filesystem-watcher-protocol.ts +96 -96
  58. package/src/common/filesystem.ts +43 -43
  59. package/src/common/index.ts +18 -18
  60. package/src/common/io.ts +150 -150
  61. package/src/common/remote-file-system-provider.ts +549 -549
  62. package/src/electron-browser/file-dialog/electron-file-dialog-module.ts +24 -24
  63. package/src/electron-browser/file-dialog/electron-file-dialog-service.ts +165 -165
  64. package/src/electron-browser/preload.ts +31 -31
  65. package/src/electron-common/electron-api.ts +55 -55
  66. package/src/electron-main/electron-api-main.ts +78 -78
  67. package/src/electron-main/electron-main-module.ts +23 -23
  68. package/src/node/disk-file-system-provider.spec.ts +142 -142
  69. package/src/node/disk-file-system-provider.ts +915 -915
  70. package/src/node/download/directory-archiver.spec.ts +104 -104
  71. package/src/node/download/directory-archiver.ts +126 -126
  72. package/src/node/download/file-download-backend-module.ts +32 -32
  73. package/src/node/download/file-download-cache.ts +88 -88
  74. package/src/node/download/file-download-endpoint.ts +63 -63
  75. package/src/node/download/file-download-handler.ts +304 -304
  76. package/src/node/download/test/mock-directory-archiver.ts +30 -30
  77. package/src/node/file-change-collection.spec.ts +110 -110
  78. package/src/node/file-change-collection.ts +78 -78
  79. package/src/node/filesystem-backend-module.ts +140 -140
  80. package/src/node/filesystem-watcher-client.ts +72 -72
  81. package/src/node/filesystem-watcher-dispatcher.ts +82 -82
  82. package/src/node/node-file-upload-service.ts +80 -80
  83. package/src/node/nsfw-watcher/index.ts +45 -45
  84. package/src/node/nsfw-watcher/nsfw-filesystem-service.ts +481 -481
  85. package/src/node/nsfw-watcher/nsfw-filesystem-watcher.spec.ts +182 -182
  86. package/src/node/nsfw-watcher/nsfw-options.ts +23 -23
  87. package/src/typings/dom.webkit.d.ts +77 -77
  88. package/src/typings/mv/index.d.ts +21 -21
  89. package/src/typings/nsfw/index.d.ts +18 -18
  90. package/src/typings/trash/index.d.ts +20 -20
package/src/common/io.ts CHANGED
@@ -1,150 +1,150 @@
1
- // *****************************************************************************
2
- // Copyright (C) 2020 TypeFox and others.
3
- //
4
- // This program and the accompanying materials are made available under the
5
- // terms of the Eclipse Public License v. 2.0 which is available at
6
- // http://www.eclipse.org/legal/epl-2.0.
7
- //
8
- // This Source Code may also be made available under the following Secondary
9
- // Licenses when the conditions for such availability set forth in the Eclipse
10
- // Public License v. 2.0 are satisfied: GNU General Public License, version 2
11
- // with the GNU Classpath Exception which is available at
12
- // https://www.gnu.org/software/classpath/license.html.
13
- //
14
- // SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
15
- // *****************************************************************************
16
- /*---------------------------------------------------------------------------------------------
17
- * Copyright (c) Microsoft Corporation. All rights reserved.
18
- * Licensed under the MIT License. See License.txt in the project root for license information.
19
- *--------------------------------------------------------------------------------------------*/
20
- // based on https://github.com/microsoft/vscode/blob/04c36be045a94fee58e5f8992d3e3fd980294a84/src/vs/platform/files/common/io.ts
21
-
22
- /* eslint-disable max-len */
23
-
24
- import URI from '@theia/core/lib/common/uri';
25
- import { BinaryBuffer } from '@theia/core/lib/common//buffer';
26
- import { CancellationToken, cancelled as canceled } from '@theia/core/lib/common/cancellation';
27
- import { FileSystemProviderWithOpenReadWriteCloseCapability, FileReadStreamOptions, ensureFileSystemProviderError, createFileSystemProviderError, FileSystemProviderErrorCode } from './files';
28
- import { WriteableStream, ErrorTransformer, DataTransformer } from '@theia/core/lib/common/stream';
29
-
30
- export interface CreateReadStreamOptions extends FileReadStreamOptions {
31
-
32
- /**
33
- * The size of the buffer to use before sending to the stream.
34
- */
35
- bufferSize: number;
36
-
37
- /**
38
- * Allows to massage any possibly error that happens during reading.
39
- */
40
- errorTransformer?: ErrorTransformer;
41
- }
42
-
43
- /**
44
- * A helper to read a file from a provider with open/read/close capability into a stream.
45
- */
46
- export async function readFileIntoStream<T>(
47
- provider: FileSystemProviderWithOpenReadWriteCloseCapability,
48
- resource: URI,
49
- target: WriteableStream<T>,
50
- transformer: DataTransformer<BinaryBuffer, T>,
51
- options: CreateReadStreamOptions,
52
- token: CancellationToken
53
- ): Promise<void> {
54
- let error: Error | undefined = undefined;
55
-
56
- try {
57
- await doReadFileIntoStream(provider, resource, target, transformer, options, token);
58
- } catch (err) {
59
- error = err;
60
- } finally {
61
- if (error && options.errorTransformer) {
62
- error = options.errorTransformer(error);
63
- }
64
-
65
- target.end(error);
66
- }
67
- }
68
-
69
- async function doReadFileIntoStream<T>(provider: FileSystemProviderWithOpenReadWriteCloseCapability, resource: URI, target: WriteableStream<T>, transformer: DataTransformer<BinaryBuffer, T>, options: CreateReadStreamOptions, token: CancellationToken): Promise<void> {
70
-
71
- // Check for cancellation
72
- throwIfCancelled(token);
73
-
74
- // open handle through provider
75
- const handle = await provider.open(resource, { create: false });
76
-
77
- // Check for cancellation
78
- throwIfCancelled(token);
79
-
80
- try {
81
- let totalBytesRead = 0;
82
- let bytesRead = 0;
83
- let allowedRemainingBytes = (options && typeof options.length === 'number') ? options.length : undefined;
84
-
85
- let buffer = BinaryBuffer.alloc(Math.min(options.bufferSize, typeof allowedRemainingBytes === 'number' ? allowedRemainingBytes : options.bufferSize));
86
-
87
- let posInFile = options && typeof options.position === 'number' ? options.position : 0;
88
- let posInBuffer = 0;
89
- do {
90
- // read from source (handle) at current position (pos) into buffer (buffer) at
91
- // buffer position (posInBuffer) up to the size of the buffer (buffer.byteLength).
92
- bytesRead = await provider.read(handle, posInFile, buffer.buffer, posInBuffer, buffer.byteLength - posInBuffer);
93
-
94
- posInFile += bytesRead;
95
- posInBuffer += bytesRead;
96
- totalBytesRead += bytesRead;
97
-
98
- if (typeof allowedRemainingBytes === 'number') {
99
- allowedRemainingBytes -= bytesRead;
100
- }
101
-
102
- // when buffer full, create a new one and emit it through stream
103
- if (posInBuffer === buffer.byteLength) {
104
- await target.write(transformer(buffer));
105
-
106
- buffer = BinaryBuffer.alloc(Math.min(options.bufferSize, typeof allowedRemainingBytes === 'number' ? allowedRemainingBytes : options.bufferSize));
107
-
108
- posInBuffer = 0;
109
- }
110
- } while (bytesRead > 0 && (typeof allowedRemainingBytes !== 'number' || allowedRemainingBytes > 0) && throwIfCancelled(token) && throwIfTooLarge(totalBytesRead, options));
111
-
112
- // wrap up with last buffer (also respect maxBytes if provided)
113
- if (posInBuffer > 0) {
114
- let lastChunkLength = posInBuffer;
115
- if (typeof allowedRemainingBytes === 'number') {
116
- lastChunkLength = Math.min(posInBuffer, allowedRemainingBytes);
117
- }
118
-
119
- target.write(transformer(buffer.slice(0, lastChunkLength)));
120
- }
121
- } catch (error) {
122
- throw ensureFileSystemProviderError(error);
123
- } finally {
124
- await provider.close(handle);
125
- }
126
- }
127
-
128
- function throwIfCancelled(token: CancellationToken): boolean {
129
- if (token.isCancellationRequested) {
130
- throw canceled();
131
- }
132
-
133
- return true;
134
- }
135
-
136
- function throwIfTooLarge(totalBytesRead: number, options: CreateReadStreamOptions): boolean {
137
-
138
- // Return early if file is too large to load and we have configured limits
139
- if (options?.limits) {
140
- if (typeof options.limits.memory === 'number' && totalBytesRead > options.limits.memory) {
141
- throw createFileSystemProviderError('To open a file of this size, you need to restart and allow it to use more memory', FileSystemProviderErrorCode.FileExceedsMemoryLimit);
142
- }
143
-
144
- if (typeof options.limits.size === 'number' && totalBytesRead > options.limits.size) {
145
- throw createFileSystemProviderError('File is too large to open', FileSystemProviderErrorCode.FileTooLarge);
146
- }
147
- }
148
-
149
- return true;
150
- }
1
+ // *****************************************************************************
2
+ // Copyright (C) 2020 TypeFox and others.
3
+ //
4
+ // This program and the accompanying materials are made available under the
5
+ // terms of the Eclipse Public License v. 2.0 which is available at
6
+ // http://www.eclipse.org/legal/epl-2.0.
7
+ //
8
+ // This Source Code may also be made available under the following Secondary
9
+ // Licenses when the conditions for such availability set forth in the Eclipse
10
+ // Public License v. 2.0 are satisfied: GNU General Public License, version 2
11
+ // with the GNU Classpath Exception which is available at
12
+ // https://www.gnu.org/software/classpath/license.html.
13
+ //
14
+ // SPDX-License-Identifier: EPL-2.0 OR GPL-2.0-only WITH Classpath-exception-2.0
15
+ // *****************************************************************************
16
+ /*---------------------------------------------------------------------------------------------
17
+ * Copyright (c) Microsoft Corporation. All rights reserved.
18
+ * Licensed under the MIT License. See License.txt in the project root for license information.
19
+ *--------------------------------------------------------------------------------------------*/
20
+ // based on https://github.com/microsoft/vscode/blob/04c36be045a94fee58e5f8992d3e3fd980294a84/src/vs/platform/files/common/io.ts
21
+
22
+ /* eslint-disable max-len */
23
+
24
+ import URI from '@theia/core/lib/common/uri';
25
+ import { BinaryBuffer } from '@theia/core/lib/common//buffer';
26
+ import { CancellationToken, cancelled as canceled } from '@theia/core/lib/common/cancellation';
27
+ import { FileSystemProviderWithOpenReadWriteCloseCapability, FileReadStreamOptions, ensureFileSystemProviderError, createFileSystemProviderError, FileSystemProviderErrorCode } from './files';
28
+ import { WriteableStream, ErrorTransformer, DataTransformer } from '@theia/core/lib/common/stream';
29
+
30
+ export interface CreateReadStreamOptions extends FileReadStreamOptions {
31
+
32
+ /**
33
+ * The size of the buffer to use before sending to the stream.
34
+ */
35
+ bufferSize: number;
36
+
37
+ /**
38
+ * Allows to massage any possibly error that happens during reading.
39
+ */
40
+ errorTransformer?: ErrorTransformer;
41
+ }
42
+
43
+ /**
44
+ * A helper to read a file from a provider with open/read/close capability into a stream.
45
+ */
46
+ export async function readFileIntoStream<T>(
47
+ provider: FileSystemProviderWithOpenReadWriteCloseCapability,
48
+ resource: URI,
49
+ target: WriteableStream<T>,
50
+ transformer: DataTransformer<BinaryBuffer, T>,
51
+ options: CreateReadStreamOptions,
52
+ token: CancellationToken
53
+ ): Promise<void> {
54
+ let error: Error | undefined = undefined;
55
+
56
+ try {
57
+ await doReadFileIntoStream(provider, resource, target, transformer, options, token);
58
+ } catch (err) {
59
+ error = err;
60
+ } finally {
61
+ if (error && options.errorTransformer) {
62
+ error = options.errorTransformer(error);
63
+ }
64
+
65
+ target.end(error);
66
+ }
67
+ }
68
+
69
+ async function doReadFileIntoStream<T>(provider: FileSystemProviderWithOpenReadWriteCloseCapability, resource: URI, target: WriteableStream<T>, transformer: DataTransformer<BinaryBuffer, T>, options: CreateReadStreamOptions, token: CancellationToken): Promise<void> {
70
+
71
+ // Check for cancellation
72
+ throwIfCancelled(token);
73
+
74
+ // open handle through provider
75
+ const handle = await provider.open(resource, { create: false });
76
+
77
+ // Check for cancellation
78
+ throwIfCancelled(token);
79
+
80
+ try {
81
+ let totalBytesRead = 0;
82
+ let bytesRead = 0;
83
+ let allowedRemainingBytes = (options && typeof options.length === 'number') ? options.length : undefined;
84
+
85
+ let buffer = BinaryBuffer.alloc(Math.min(options.bufferSize, typeof allowedRemainingBytes === 'number' ? allowedRemainingBytes : options.bufferSize));
86
+
87
+ let posInFile = options && typeof options.position === 'number' ? options.position : 0;
88
+ let posInBuffer = 0;
89
+ do {
90
+ // read from source (handle) at current position (pos) into buffer (buffer) at
91
+ // buffer position (posInBuffer) up to the size of the buffer (buffer.byteLength).
92
+ bytesRead = await provider.read(handle, posInFile, buffer.buffer, posInBuffer, buffer.byteLength - posInBuffer);
93
+
94
+ posInFile += bytesRead;
95
+ posInBuffer += bytesRead;
96
+ totalBytesRead += bytesRead;
97
+
98
+ if (typeof allowedRemainingBytes === 'number') {
99
+ allowedRemainingBytes -= bytesRead;
100
+ }
101
+
102
+ // when buffer full, create a new one and emit it through stream
103
+ if (posInBuffer === buffer.byteLength) {
104
+ await target.write(transformer(buffer));
105
+
106
+ buffer = BinaryBuffer.alloc(Math.min(options.bufferSize, typeof allowedRemainingBytes === 'number' ? allowedRemainingBytes : options.bufferSize));
107
+
108
+ posInBuffer = 0;
109
+ }
110
+ } while (bytesRead > 0 && (typeof allowedRemainingBytes !== 'number' || allowedRemainingBytes > 0) && throwIfCancelled(token) && throwIfTooLarge(totalBytesRead, options));
111
+
112
+ // wrap up with last buffer (also respect maxBytes if provided)
113
+ if (posInBuffer > 0) {
114
+ let lastChunkLength = posInBuffer;
115
+ if (typeof allowedRemainingBytes === 'number') {
116
+ lastChunkLength = Math.min(posInBuffer, allowedRemainingBytes);
117
+ }
118
+
119
+ target.write(transformer(buffer.slice(0, lastChunkLength)));
120
+ }
121
+ } catch (error) {
122
+ throw ensureFileSystemProviderError(error);
123
+ } finally {
124
+ await provider.close(handle);
125
+ }
126
+ }
127
+
128
+ function throwIfCancelled(token: CancellationToken): boolean {
129
+ if (token.isCancellationRequested) {
130
+ throw canceled();
131
+ }
132
+
133
+ return true;
134
+ }
135
+
136
+ function throwIfTooLarge(totalBytesRead: number, options: CreateReadStreamOptions): boolean {
137
+
138
+ // Return early if file is too large to load and we have configured limits
139
+ if (options?.limits) {
140
+ if (typeof options.limits.memory === 'number' && totalBytesRead > options.limits.memory) {
141
+ throw createFileSystemProviderError('To open a file of this size, you need to restart and allow it to use more memory', FileSystemProviderErrorCode.FileExceedsMemoryLimit);
142
+ }
143
+
144
+ if (typeof options.limits.size === 'number' && totalBytesRead > options.limits.size) {
145
+ throw createFileSystemProviderError('File is too large to open', FileSystemProviderErrorCode.FileTooLarge);
146
+ }
147
+ }
148
+
149
+ return true;
150
+ }