@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
@@ -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"/>