@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
@@ -1,182 +1,182 @@
1
- // *****************************************************************************
2
- // Copyright (C) 2018 Ericsson 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
- import * as temp from 'temp';
18
- import * as chai from 'chai';
19
- import * as cp from 'child_process';
20
- import * as fs from '@theia/core/shared/fs-extra';
21
- import * as assert from 'assert';
22
- import URI from '@theia/core/lib/common/uri';
23
- import { FileUri } from '@theia/core/lib/node';
24
- import { NsfwFileSystemWatcherService } from './nsfw-filesystem-service';
25
- import { DidFilesChangedParams, FileChange, FileChangeType } from '../../common/filesystem-watcher-protocol';
26
-
27
- const expect = chai.expect;
28
- const track = temp.track();
29
-
30
- describe('nsfw-filesystem-watcher', function (): void {
31
-
32
- let root: URI;
33
- let watcherService: NsfwFileSystemWatcherService;
34
- let watcherId: number;
35
-
36
- this.timeout(100000);
37
-
38
- beforeEach(async () => {
39
- let tempPath = temp.mkdirSync('node-fs-root');
40
- // Sometimes tempPath will use some Windows 8.3 short name in its path. This is a problem
41
- // since NSFW always returns paths with long names. We need to convert here.
42
- // See: https://stackoverflow.com/a/34473971/7983255
43
- if (process.platform === 'win32') {
44
- tempPath = cp.execSync(`powershell "(Get-Item -LiteralPath '${tempPath}').FullName"`, {
45
- encoding: 'utf8',
46
- }).trim();
47
- }
48
- root = FileUri.create(fs.realpathSync(tempPath));
49
- watcherService = createNsfwFileSystemWatcherService();
50
- watcherId = await watcherService.watchFileChanges(0, root.toString());
51
- await sleep(2000);
52
- });
53
-
54
- afterEach(async () => {
55
- track.cleanupSync();
56
- watcherService.dispose();
57
- });
58
-
59
- it('Should receive file changes events from in the workspace by default.', async function (): Promise<void> {
60
- const actualUris = new Set<string>();
61
-
62
- const watcherClient = {
63
- onDidFilesChanged(event: DidFilesChangedParams): void {
64
- event.changes.forEach(c => actualUris.add(c.uri.toString()));
65
- },
66
- onError(): void {
67
- }
68
- };
69
- watcherService.setClient(watcherClient);
70
-
71
- const expectedUris = [
72
- root.resolve('foo').toString(),
73
- root.withPath(root.path.join('foo', 'bar')).toString(),
74
- root.withPath(root.path.join('foo', 'bar', 'baz.txt')).toString()
75
- ];
76
-
77
- fs.mkdirSync(FileUri.fsPath(root.resolve('foo')));
78
- expect(fs.statSync(FileUri.fsPath(root.resolve('foo'))).isDirectory()).to.be.true;
79
- await sleep(2000);
80
-
81
- fs.mkdirSync(FileUri.fsPath(root.resolve('foo').resolve('bar')));
82
- expect(fs.statSync(FileUri.fsPath(root.resolve('foo').resolve('bar'))).isDirectory()).to.be.true;
83
- await sleep(2000);
84
-
85
- fs.writeFileSync(FileUri.fsPath(root.resolve('foo').resolve('bar').resolve('baz.txt')), 'baz');
86
- expect(fs.readFileSync(FileUri.fsPath(root.resolve('foo').resolve('bar').resolve('baz.txt')), 'utf8')).to.be.equal('baz');
87
- await sleep(2000);
88
-
89
- assert.deepStrictEqual([...actualUris], expectedUris);
90
- });
91
-
92
- it('Should not receive file changes events from in the workspace by default if unwatched', async function (): Promise<void> {
93
- const actualUris = new Set<string>();
94
-
95
- const watcherClient = {
96
- onDidFilesChanged(event: DidFilesChangedParams): void {
97
- event.changes.forEach(c => actualUris.add(c.uri.toString()));
98
- },
99
- onError(): void {
100
- }
101
- };
102
- watcherService.setClient(watcherClient);
103
-
104
- /* Unwatch root */
105
- await watcherService.unwatchFileChanges(watcherId);
106
-
107
- fs.mkdirSync(FileUri.fsPath(root.resolve('foo')));
108
- expect(fs.statSync(FileUri.fsPath(root.resolve('foo'))).isDirectory()).to.be.true;
109
- await sleep(2000);
110
-
111
- fs.mkdirSync(FileUri.fsPath(root.resolve('foo').resolve('bar')));
112
- expect(fs.statSync(FileUri.fsPath(root.resolve('foo').resolve('bar'))).isDirectory()).to.be.true;
113
- await sleep(2000);
114
-
115
- fs.writeFileSync(FileUri.fsPath(root.resolve('foo').resolve('bar').resolve('baz.txt')), 'baz');
116
- expect(fs.readFileSync(FileUri.fsPath(root.resolve('foo').resolve('bar').resolve('baz.txt')), 'utf8')).to.be.equal('baz');
117
- await sleep(2000);
118
-
119
- assert.deepStrictEqual(actualUris.size, 0);
120
- });
121
-
122
- it('Renaming should emit a DELETED change followed by ADDED', async function (): Promise<void> {
123
- const file_txt = root.resolve('file.txt');
124
- const FILE_txt = root.resolve('FILE.txt');
125
- const changes: FileChange[] = [];
126
- watcherService.setClient({
127
- onDidFilesChanged: event => event.changes.forEach(change => changes.push(change)),
128
- onError: console.error
129
- });
130
- await fs.promises.writeFile(
131
- FileUri.fsPath(file_txt),
132
- 'random content\n'
133
- );
134
- await sleep(1000);
135
- await fs.promises.rename(
136
- FileUri.fsPath(file_txt),
137
- FileUri.fsPath(FILE_txt)
138
- );
139
- await sleep(1000);
140
- try {
141
- expect(changes).deep.eq([
142
- // initial file creation change event:
143
- { type: FileChangeType.ADDED, uri: file_txt.toString() },
144
- // rename change events:
145
- { type: FileChangeType.DELETED, uri: file_txt.toString() },
146
- { type: FileChangeType.ADDED, uri: FILE_txt.toString() }
147
- ]);
148
- } catch (error) {
149
- // TODO: remove this try/catch once the bug on macOS is fixed.
150
- // See https://github.com/Axosoft/nsfw/issues/146
151
- if (process.platform !== 'darwin') {
152
- throw error;
153
- }
154
- // On macOS we only get ADDED events for some reason
155
- expect(changes).deep.eq([
156
- // initial file creation change event:
157
- { type: FileChangeType.ADDED, uri: file_txt.toString() },
158
- // rename change events:
159
- { type: FileChangeType.ADDED, uri: file_txt.toString() },
160
- { type: FileChangeType.ADDED, uri: FILE_txt.toString() }
161
- ]);
162
- // Mark the test case as skipped so it stands out that the bogus branch got tested
163
- this.skip();
164
- }
165
- });
166
-
167
- function createNsfwFileSystemWatcherService(): NsfwFileSystemWatcherService {
168
- return new NsfwFileSystemWatcherService({
169
- verbose: true
170
- });
171
- }
172
-
173
- function sleep(time: number): Promise<unknown> {
174
- return new Promise(resolve => setTimeout(resolve, time));
175
- }
176
-
177
- });
178
-
179
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
180
- process.on('unhandledRejection', (reason: any) => {
181
- console.error('Unhandled promise rejection: ' + reason);
182
- });
1
+ // *****************************************************************************
2
+ // Copyright (C) 2018 Ericsson 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
+ import * as temp from 'temp';
18
+ import * as chai from 'chai';
19
+ import * as cp from 'child_process';
20
+ import * as fs from '@theia/core/shared/fs-extra';
21
+ import * as assert from 'assert';
22
+ import URI from '@theia/core/lib/common/uri';
23
+ import { FileUri } from '@theia/core/lib/node';
24
+ import { NsfwFileSystemWatcherService } from './nsfw-filesystem-service';
25
+ import { DidFilesChangedParams, FileChange, FileChangeType } from '../../common/filesystem-watcher-protocol';
26
+
27
+ const expect = chai.expect;
28
+ const track = temp.track();
29
+
30
+ describe('nsfw-filesystem-watcher', function (): void {
31
+
32
+ let root: URI;
33
+ let watcherService: NsfwFileSystemWatcherService;
34
+ let watcherId: number;
35
+
36
+ this.timeout(100000);
37
+
38
+ beforeEach(async () => {
39
+ let tempPath = temp.mkdirSync('node-fs-root');
40
+ // Sometimes tempPath will use some Windows 8.3 short name in its path. This is a problem
41
+ // since NSFW always returns paths with long names. We need to convert here.
42
+ // See: https://stackoverflow.com/a/34473971/7983255
43
+ if (process.platform === 'win32') {
44
+ tempPath = cp.execSync(`powershell "(Get-Item -LiteralPath '${tempPath}').FullName"`, {
45
+ encoding: 'utf8',
46
+ }).trim();
47
+ }
48
+ root = FileUri.create(fs.realpathSync(tempPath));
49
+ watcherService = createNsfwFileSystemWatcherService();
50
+ watcherId = await watcherService.watchFileChanges(0, root.toString());
51
+ await sleep(2000);
52
+ });
53
+
54
+ afterEach(async () => {
55
+ track.cleanupSync();
56
+ watcherService.dispose();
57
+ });
58
+
59
+ it('Should receive file changes events from in the workspace by default.', async function (): Promise<void> {
60
+ const actualUris = new Set<string>();
61
+
62
+ const watcherClient = {
63
+ onDidFilesChanged(event: DidFilesChangedParams): void {
64
+ event.changes.forEach(c => actualUris.add(c.uri.toString()));
65
+ },
66
+ onError(): void {
67
+ }
68
+ };
69
+ watcherService.setClient(watcherClient);
70
+
71
+ const expectedUris = [
72
+ root.resolve('foo').toString(),
73
+ root.withPath(root.path.join('foo', 'bar')).toString(),
74
+ root.withPath(root.path.join('foo', 'bar', 'baz.txt')).toString()
75
+ ];
76
+
77
+ fs.mkdirSync(FileUri.fsPath(root.resolve('foo')));
78
+ expect(fs.statSync(FileUri.fsPath(root.resolve('foo'))).isDirectory()).to.be.true;
79
+ await sleep(2000);
80
+
81
+ fs.mkdirSync(FileUri.fsPath(root.resolve('foo').resolve('bar')));
82
+ expect(fs.statSync(FileUri.fsPath(root.resolve('foo').resolve('bar'))).isDirectory()).to.be.true;
83
+ await sleep(2000);
84
+
85
+ fs.writeFileSync(FileUri.fsPath(root.resolve('foo').resolve('bar').resolve('baz.txt')), 'baz');
86
+ expect(fs.readFileSync(FileUri.fsPath(root.resolve('foo').resolve('bar').resolve('baz.txt')), 'utf8')).to.be.equal('baz');
87
+ await sleep(2000);
88
+
89
+ assert.deepStrictEqual([...actualUris], expectedUris);
90
+ });
91
+
92
+ it('Should not receive file changes events from in the workspace by default if unwatched', async function (): Promise<void> {
93
+ const actualUris = new Set<string>();
94
+
95
+ const watcherClient = {
96
+ onDidFilesChanged(event: DidFilesChangedParams): void {
97
+ event.changes.forEach(c => actualUris.add(c.uri.toString()));
98
+ },
99
+ onError(): void {
100
+ }
101
+ };
102
+ watcherService.setClient(watcherClient);
103
+
104
+ /* Unwatch root */
105
+ await watcherService.unwatchFileChanges(watcherId);
106
+
107
+ fs.mkdirSync(FileUri.fsPath(root.resolve('foo')));
108
+ expect(fs.statSync(FileUri.fsPath(root.resolve('foo'))).isDirectory()).to.be.true;
109
+ await sleep(2000);
110
+
111
+ fs.mkdirSync(FileUri.fsPath(root.resolve('foo').resolve('bar')));
112
+ expect(fs.statSync(FileUri.fsPath(root.resolve('foo').resolve('bar'))).isDirectory()).to.be.true;
113
+ await sleep(2000);
114
+
115
+ fs.writeFileSync(FileUri.fsPath(root.resolve('foo').resolve('bar').resolve('baz.txt')), 'baz');
116
+ expect(fs.readFileSync(FileUri.fsPath(root.resolve('foo').resolve('bar').resolve('baz.txt')), 'utf8')).to.be.equal('baz');
117
+ await sleep(2000);
118
+
119
+ assert.deepStrictEqual(actualUris.size, 0);
120
+ });
121
+
122
+ it('Renaming should emit a DELETED change followed by ADDED', async function (): Promise<void> {
123
+ const file_txt = root.resolve('file.txt');
124
+ const FILE_txt = root.resolve('FILE.txt');
125
+ const changes: FileChange[] = [];
126
+ watcherService.setClient({
127
+ onDidFilesChanged: event => event.changes.forEach(change => changes.push(change)),
128
+ onError: console.error
129
+ });
130
+ await fs.promises.writeFile(
131
+ FileUri.fsPath(file_txt),
132
+ 'random content\n'
133
+ );
134
+ await sleep(1000);
135
+ await fs.promises.rename(
136
+ FileUri.fsPath(file_txt),
137
+ FileUri.fsPath(FILE_txt)
138
+ );
139
+ await sleep(1000);
140
+ try {
141
+ expect(changes).deep.eq([
142
+ // initial file creation change event:
143
+ { type: FileChangeType.ADDED, uri: file_txt.toString() },
144
+ // rename change events:
145
+ { type: FileChangeType.DELETED, uri: file_txt.toString() },
146
+ { type: FileChangeType.ADDED, uri: FILE_txt.toString() }
147
+ ]);
148
+ } catch (error) {
149
+ // TODO: remove this try/catch once the bug on macOS is fixed.
150
+ // See https://github.com/Axosoft/nsfw/issues/146
151
+ if (process.platform !== 'darwin') {
152
+ throw error;
153
+ }
154
+ // On macOS we only get ADDED events for some reason
155
+ expect(changes).deep.eq([
156
+ // initial file creation change event:
157
+ { type: FileChangeType.ADDED, uri: file_txt.toString() },
158
+ // rename change events:
159
+ { type: FileChangeType.ADDED, uri: file_txt.toString() },
160
+ { type: FileChangeType.ADDED, uri: FILE_txt.toString() }
161
+ ]);
162
+ // Mark the test case as skipped so it stands out that the bogus branch got tested
163
+ this.skip();
164
+ }
165
+ });
166
+
167
+ function createNsfwFileSystemWatcherService(): NsfwFileSystemWatcherService {
168
+ return new NsfwFileSystemWatcherService({
169
+ verbose: true
170
+ });
171
+ }
172
+
173
+ function sleep(time: number): Promise<unknown> {
174
+ return new Promise(resolve => setTimeout(resolve, time));
175
+ }
176
+
177
+ });
178
+
179
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
180
+ process.on('unhandledRejection', (reason: any) => {
181
+ console.error('Unhandled promise rejection: ' + reason);
182
+ });
@@ -1,23 +1,23 @@
1
- // *****************************************************************************
2
- // Copyright (C) 2017-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
- import * as nsfw from '@theia/core/shared/nsfw';
18
-
19
- /**
20
- * Inversify service identifier allowing extensions to override options passed to nsfw by the file watcher.
21
- */
22
- export const NsfwOptions = Symbol('NsfwOptions');
23
- export type NsfwOptions = nsfw.Options;
1
+ // *****************************************************************************
2
+ // Copyright (C) 2017-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
+ import * as nsfw from '@theia/core/shared/nsfw';
18
+
19
+ /**
20
+ * Inversify service identifier allowing extensions to override options passed to nsfw by the file watcher.
21
+ */
22
+ export const NsfwOptions = Symbol('NsfwOptions');
23
+ export type NsfwOptions = nsfw.Options;
@@ -1,77 +1,77 @@
1
- // *****************************************************************************
2
- // Copyright (C) 2018 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
- /* eslint-disable no-var */
18
-
19
- type WebKitEntriesCallback = ((entries: WebKitEntry[]) => void) | { handleEvent(entries: WebKitEntry[]): void; };
20
-
21
- type WebKitErrorCallback = ((err: DOMError) => void) | { handleEvent(err: DOMError): void; };
22
-
23
- type WebKitFileCallback = ((file: File) => void) | { handleEvent(file: File): void; };
24
-
25
- interface WebKitDirectoryEntry extends WebKitEntry {
26
- createReader(): WebKitDirectoryReader;
27
- }
28
-
29
- declare var WebKitDirectoryEntry: {
30
- prototype: WebKitDirectoryEntry;
31
- new(): WebKitDirectoryEntry;
32
- };
33
-
34
- interface WebKitDirectoryReader {
35
- readEntries(successCallback: WebKitEntriesCallback, errorCallback?: WebKitErrorCallback): void;
36
- }
37
-
38
- declare var WebKitDirectoryReader: {
39
- prototype: WebKitDirectoryReader;
40
- new(): WebKitDirectoryReader;
41
- };
42
-
43
- interface WebKitEntry {
44
- readonly filesystem: WebKitFileSystem;
45
- readonly fullPath: string;
46
- readonly isDirectory: boolean;
47
- readonly isFile: boolean;
48
- readonly name: string;
49
- }
50
-
51
- declare var WebKitEntry: {
52
- prototype: WebKitEntry;
53
- new(): WebKitEntry;
54
- };
55
-
56
- interface WebKitFileEntry extends WebKitEntry {
57
- file(successCallback: WebKitFileCallback, errorCallback?: WebKitErrorCallback): void;
58
- }
59
-
60
- declare var WebKitFileEntry: {
61
- prototype: WebKitFileEntry;
62
- new(): WebKitFileEntry;
63
- };
64
-
65
- interface WebKitFileSystem {
66
- readonly name: string;
67
- readonly root: WebKitDirectoryEntry;
68
- }
69
-
70
- declare var WebKitFileSystem: {
71
- prototype: WebKitFileSystem;
72
- new(): WebKitFileSystem;
73
- };
74
-
75
- declare interface DataTransferItem {
76
- webkitGetAsEntry(): WebKitEntry | null;
77
- }
1
+ // *****************************************************************************
2
+ // Copyright (C) 2018 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
+ /* eslint-disable no-var */
18
+
19
+ type WebKitEntriesCallback = ((entries: WebKitEntry[]) => void) | { handleEvent(entries: WebKitEntry[]): void; };
20
+
21
+ type WebKitErrorCallback = ((err: DOMError) => void) | { handleEvent(err: DOMError): void; };
22
+
23
+ type WebKitFileCallback = ((file: File) => void) | { handleEvent(file: File): void; };
24
+
25
+ interface WebKitDirectoryEntry extends WebKitEntry {
26
+ createReader(): WebKitDirectoryReader;
27
+ }
28
+
29
+ declare var WebKitDirectoryEntry: {
30
+ prototype: WebKitDirectoryEntry;
31
+ new(): WebKitDirectoryEntry;
32
+ };
33
+
34
+ interface WebKitDirectoryReader {
35
+ readEntries(successCallback: WebKitEntriesCallback, errorCallback?: WebKitErrorCallback): void;
36
+ }
37
+
38
+ declare var WebKitDirectoryReader: {
39
+ prototype: WebKitDirectoryReader;
40
+ new(): WebKitDirectoryReader;
41
+ };
42
+
43
+ interface WebKitEntry {
44
+ readonly filesystem: WebKitFileSystem;
45
+ readonly fullPath: string;
46
+ readonly isDirectory: boolean;
47
+ readonly isFile: boolean;
48
+ readonly name: string;
49
+ }
50
+
51
+ declare var WebKitEntry: {
52
+ prototype: WebKitEntry;
53
+ new(): WebKitEntry;
54
+ };
55
+
56
+ interface WebKitFileEntry extends WebKitEntry {
57
+ file(successCallback: WebKitFileCallback, errorCallback?: WebKitErrorCallback): void;
58
+ }
59
+
60
+ declare var WebKitFileEntry: {
61
+ prototype: WebKitFileEntry;
62
+ new(): WebKitFileEntry;
63
+ };
64
+
65
+ interface WebKitFileSystem {
66
+ readonly name: string;
67
+ readonly root: WebKitDirectoryEntry;
68
+ }
69
+
70
+ declare var WebKitFileSystem: {
71
+ prototype: WebKitFileSystem;
72
+ new(): WebKitFileSystem;
73
+ };
74
+
75
+ declare interface DataTransferItem {
76
+ webkitGetAsEntry(): WebKitEntry | null;
77
+ }
@@ -1,21 +1,21 @@
1
- // *****************************************************************************
2
- // Copyright (C) 2017 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
- export = mv;
18
- declare module mv { }
19
- // eslint-disable-next-line @typescript-eslint/consistent-type-definitions
20
- type MvOptions = { mkdirp?: boolean, clobber?: boolean, limit?: number };
21
- declare function mv(sourcePath: string, targetPath: string, options?: MvOptions, cb?: (error: NodeJS.ErrnoException) => void): void;
1
+ // *****************************************************************************
2
+ // Copyright (C) 2017 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
+ export = mv;
18
+ declare module mv { }
19
+ // eslint-disable-next-line @typescript-eslint/consistent-type-definitions
20
+ type MvOptions = { mkdirp?: boolean, clobber?: boolean, limit?: number };
21
+ declare function mv(sourcePath: string, targetPath: string, options?: MvOptions, cb?: (error: NodeJS.ErrnoException) => void): void;
@@ -1,18 +1,18 @@
1
- // *****************************************************************************
2
- // Copyright (C) 2018 Ericsson 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
- // eslint-disable-next-line spaced-comment
18
- /// <reference types="@theia/core/src/typings/nsfw/index"/>
1
+ // *****************************************************************************
2
+ // Copyright (C) 2018 Ericsson 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
+ // eslint-disable-next-line spaced-comment
18
+ /// <reference types="@theia/core/src/typings/nsfw/index"/>