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

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 (102) hide show
  1. package/README.md +30 -30
  2. package/lib/browser/file-resource.d.ts +2 -0
  3. package/lib/browser/file-resource.d.ts.map +1 -1
  4. package/lib/browser/file-resource.js +11 -0
  5. package/lib/browser/file-resource.js.map +1 -1
  6. package/lib/browser/file-resource.spec.d.ts +2 -0
  7. package/lib/browser/file-resource.spec.d.ts.map +1 -0
  8. package/lib/browser/file-resource.spec.js +191 -0
  9. package/lib/browser/file-resource.spec.js.map +1 -0
  10. package/lib/browser/file-service.d.ts +1 -0
  11. package/lib/browser/file-service.d.ts.map +1 -1
  12. package/lib/browser/file-service.js +3 -0
  13. package/lib/browser/file-service.js.map +1 -1
  14. package/package.json +4 -4
  15. package/src/browser/breadcrumbs/filepath-breadcrumb.ts +43 -43
  16. package/src/browser/breadcrumbs/filepath-breadcrumbs-container.ts +65 -65
  17. package/src/browser/breadcrumbs/filepath-breadcrumbs-contribution.ts +129 -129
  18. package/src/browser/download/file-download-command-contribution.ts +83 -83
  19. package/src/browser/download/file-download-frontend-module.ts +25 -25
  20. package/src/browser/download/file-download-service.ts +179 -179
  21. package/src/browser/file-dialog/file-dialog-container.ts +67 -67
  22. package/src/browser/file-dialog/file-dialog-hidden-files-renderer.tsx +59 -59
  23. package/src/browser/file-dialog/file-dialog-model.ts +96 -96
  24. package/src/browser/file-dialog/file-dialog-module.ts +44 -44
  25. package/src/browser/file-dialog/file-dialog-service.ts +99 -99
  26. package/src/browser/file-dialog/file-dialog-tree-filters-renderer.tsx +100 -100
  27. package/src/browser/file-dialog/file-dialog-tree.ts +89 -89
  28. package/src/browser/file-dialog/file-dialog-widget.ts +75 -75
  29. package/src/browser/file-dialog/file-dialog.ts +434 -434
  30. package/src/browser/file-dialog/index.ts +20 -20
  31. package/src/browser/file-resource.spec.ts +255 -0
  32. package/src/browser/file-resource.ts +402 -390
  33. package/src/browser/file-selection.ts +44 -44
  34. package/src/browser/file-service.ts +1845 -1841
  35. package/src/browser/file-tree/file-tree-container.ts +36 -36
  36. package/src/browser/file-tree/file-tree-decorator-adapter.ts +159 -159
  37. package/src/browser/file-tree/file-tree-label-provider.ts +53 -53
  38. package/src/browser/file-tree/file-tree-model.ts +212 -212
  39. package/src/browser/file-tree/file-tree-widget.tsx +327 -327
  40. package/src/browser/file-tree/file-tree.ts +183 -183
  41. package/src/browser/file-tree/index.ts +22 -22
  42. package/src/browser/file-upload-service.ts +547 -547
  43. package/src/browser/filesystem-frontend-contribution.ts +396 -396
  44. package/src/browser/filesystem-frontend-module.ts +77 -77
  45. package/src/browser/filesystem-preferences.ts +139 -139
  46. package/src/browser/filesystem-saveable-service.ts +138 -138
  47. package/src/browser/filesystem-watcher-error-handler.ts +60 -60
  48. package/src/browser/index.ts +21 -21
  49. package/src/browser/location/index.ts +18 -18
  50. package/src/browser/location/location-renderer.tsx +406 -406
  51. package/src/browser/location/location-service.ts +22 -22
  52. package/src/browser/remote-file-service-contribution.ts +38 -38
  53. package/src/browser/style/file-dialog.css +208 -208
  54. package/src/browser/style/file-icons.css +64 -64
  55. package/src/browser/style/filepath-breadcrumbs.css +20 -20
  56. package/src/browser/style/index.css +36 -36
  57. package/src/browser-only/browser-only-filesystem-frontend-module.ts +38 -38
  58. package/src/browser-only/browser-only-filesystem-provider-server.ts +32 -32
  59. package/src/browser-only/browserfs-filesystem-initialization.ts +61 -61
  60. package/src/browser-only/browserfs-filesystem-provider.ts +462 -462
  61. package/src/common/delegating-file-system-provider.ts +226 -226
  62. package/src/common/download/README.md +30 -30
  63. package/src/common/download/file-download-data.ts +27 -27
  64. package/src/common/file-upload.ts +17 -17
  65. package/src/common/files.spec.ts +51 -51
  66. package/src/common/files.ts +997 -997
  67. package/src/common/filesystem-utils.spec.ts +411 -411
  68. package/src/common/filesystem-utils.ts +64 -64
  69. package/src/common/filesystem-watcher-protocol.ts +96 -96
  70. package/src/common/filesystem.ts +43 -43
  71. package/src/common/index.ts +18 -18
  72. package/src/common/io.ts +150 -150
  73. package/src/common/remote-file-system-provider.ts +549 -549
  74. package/src/electron-browser/file-dialog/electron-file-dialog-module.ts +24 -24
  75. package/src/electron-browser/file-dialog/electron-file-dialog-service.ts +165 -165
  76. package/src/electron-browser/preload.ts +31 -31
  77. package/src/electron-common/electron-api.ts +55 -55
  78. package/src/electron-main/electron-api-main.ts +78 -78
  79. package/src/electron-main/electron-main-module.ts +23 -23
  80. package/src/node/disk-file-system-provider.spec.ts +142 -142
  81. package/src/node/disk-file-system-provider.ts +915 -915
  82. package/src/node/download/directory-archiver.spec.ts +104 -104
  83. package/src/node/download/directory-archiver.ts +126 -126
  84. package/src/node/download/file-download-backend-module.ts +32 -32
  85. package/src/node/download/file-download-cache.ts +88 -88
  86. package/src/node/download/file-download-endpoint.ts +63 -63
  87. package/src/node/download/file-download-handler.ts +304 -304
  88. package/src/node/download/test/mock-directory-archiver.ts +30 -30
  89. package/src/node/file-change-collection.spec.ts +110 -110
  90. package/src/node/file-change-collection.ts +78 -78
  91. package/src/node/filesystem-backend-module.ts +140 -140
  92. package/src/node/filesystem-watcher-client.ts +72 -72
  93. package/src/node/filesystem-watcher-dispatcher.ts +82 -82
  94. package/src/node/node-file-upload-service.ts +80 -80
  95. package/src/node/nsfw-watcher/index.ts +45 -45
  96. package/src/node/nsfw-watcher/nsfw-filesystem-service.ts +481 -481
  97. package/src/node/nsfw-watcher/nsfw-filesystem-watcher.spec.ts +182 -182
  98. package/src/node/nsfw-watcher/nsfw-options.ts +23 -23
  99. package/src/typings/dom.webkit.d.ts +77 -77
  100. package/src/typings/mv/index.d.ts +21 -21
  101. package/src/typings/nsfw/index.d.ts +18 -18
  102. 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
+ }