@theia/filesystem 1.47.1 → 1.48.1

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 (249) hide show
  1. package/README.md +30 -30
  2. package/lib/browser/breadcrumbs/filepath-breadcrumb.d.ts +15 -15
  3. package/lib/browser/breadcrumbs/filepath-breadcrumb.js +41 -41
  4. package/lib/browser/breadcrumbs/filepath-breadcrumbs-container.d.ts +13 -13
  5. package/lib/browser/breadcrumbs/filepath-breadcrumbs-container.js +70 -70
  6. package/lib/browser/breadcrumbs/filepath-breadcrumbs-contribution.d.ts +27 -27
  7. package/lib/browser/breadcrumbs/filepath-breadcrumbs-contribution.js +118 -118
  8. package/lib/browser/download/file-download-command-contribution.d.ts +18 -18
  9. package/lib/browser/download/file-download-command-contribution.js +75 -75
  10. package/lib/browser/download/file-download-frontend-module.d.ts +3 -3
  11. package/lib/browser/download/file-download-frontend-module.js +25 -25
  12. package/lib/browser/download/file-download-service.d.ts +28 -28
  13. package/lib/browser/download/file-download-service.js +167 -167
  14. package/lib/browser/file-dialog/file-dialog-container.d.ts +5 -5
  15. package/lib/browser/file-dialog/file-dialog-container.js +60 -60
  16. package/lib/browser/file-dialog/file-dialog-hidden-files-renderer.d.ts +15 -15
  17. package/lib/browser/file-dialog/file-dialog-hidden-files-renderer.js +59 -59
  18. package/lib/browser/file-dialog/file-dialog-model.d.ts +25 -25
  19. package/lib/browser/file-dialog/file-dialog-model.js +100 -100
  20. package/lib/browser/file-dialog/file-dialog-module.d.ts +3 -3
  21. package/lib/browser/file-dialog/file-dialog-module.js +45 -45
  22. package/lib/browser/file-dialog/file-dialog-service.d.ts +32 -32
  23. package/lib/browser/file-dialog/file-dialog-service.js +101 -101
  24. package/lib/browser/file-dialog/file-dialog-tree-filters-renderer.d.ts +39 -39
  25. package/lib/browser/file-dialog/file-dialog-tree-filters-renderer.js +81 -81
  26. package/lib/browser/file-dialog/file-dialog-tree.d.ts +26 -26
  27. package/lib/browser/file-dialog/file-dialog-tree.js +83 -83
  28. package/lib/browser/file-dialog/file-dialog-widget.d.ts +15 -15
  29. package/lib/browser/file-dialog/file-dialog-widget.js +75 -75
  30. package/lib/browser/file-dialog/file-dialog.d.ts +129 -129
  31. package/lib/browser/file-dialog/file-dialog.js +351 -351
  32. package/lib/browser/file-dialog/index.d.ts +4 -4
  33. package/lib/browser/file-dialog/index.js +22 -22
  34. package/lib/browser/file-resource.d.ts +67 -67
  35. package/lib/browser/file-resource.js +369 -369
  36. package/lib/browser/file-selection.d.ts +14 -14
  37. package/lib/browser/file-selection.js +36 -36
  38. package/lib/browser/file-service.d.ts +425 -425
  39. package/lib/browser/file-service.d.ts.map +1 -1
  40. package/lib/browser/file-service.js +1366 -1366
  41. package/lib/browser/file-service.js.map +1 -1
  42. package/lib/browser/file-tree/file-tree-container.d.ts +3 -3
  43. package/lib/browser/file-tree/file-tree-container.js +35 -35
  44. package/lib/browser/file-tree/file-tree-decorator-adapter.d.ts +30 -30
  45. package/lib/browser/file-tree/file-tree-decorator-adapter.js +169 -169
  46. package/lib/browser/file-tree/file-tree-label-provider.d.ts +12 -12
  47. package/lib/browser/file-tree/file-tree-label-provider.js +54 -54
  48. package/lib/browser/file-tree/file-tree-model.d.ts +37 -37
  49. package/lib/browser/file-tree/file-tree-model.js +217 -217
  50. package/lib/browser/file-tree/file-tree-widget.d.ts +44 -44
  51. package/lib/browser/file-tree/file-tree-widget.js +317 -317
  52. package/lib/browser/file-tree/file-tree.d.ts +46 -46
  53. package/lib/browser/file-tree/file-tree.js +176 -176
  54. package/lib/browser/file-tree/index.d.ts +6 -6
  55. package/lib/browser/file-tree/index.js +24 -24
  56. package/lib/browser/file-upload-service.d.ts +109 -109
  57. package/lib/browser/file-upload-service.js +434 -434
  58. package/lib/browser/filesystem-frontend-contribution.d.ts +74 -63
  59. package/lib/browser/filesystem-frontend-contribution.d.ts.map +1 -1
  60. package/lib/browser/filesystem-frontend-contribution.js +356 -319
  61. package/lib/browser/filesystem-frontend-contribution.js.map +1 -1
  62. package/lib/browser/filesystem-frontend-module.d.ts +5 -5
  63. package/lib/browser/filesystem-frontend-module.js +64 -64
  64. package/lib/browser/filesystem-preferences.d.ts +29 -29
  65. package/lib/browser/filesystem-preferences.js +110 -110
  66. package/lib/browser/filesystem-save-resource-service.d.ts +29 -29
  67. package/lib/browser/filesystem-save-resource-service.js +135 -135
  68. package/lib/browser/filesystem-watcher-error-handler.d.ts +10 -10
  69. package/lib/browser/filesystem-watcher-error-handler.js +61 -61
  70. package/lib/browser/index.d.ts +5 -5
  71. package/lib/browser/index.js +23 -23
  72. package/lib/browser/location/index.d.ts +2 -2
  73. package/lib/browser/location/index.js +20 -20
  74. package/lib/browser/location/location-renderer.d.ts +100 -100
  75. package/lib/browser/location/location-renderer.js +343 -343
  76. package/lib/browser/location/location-service.d.ts +5 -5
  77. package/lib/browser/location/location-service.js +17 -17
  78. package/lib/browser/remote-file-service-contribution.d.ts +6 -6
  79. package/lib/browser/remote-file-service-contribution.js +39 -39
  80. package/lib/browser-only/browser-only-filesystem-frontend-module.d.ts +3 -3
  81. package/lib/browser-only/browser-only-filesystem-frontend-module.js +40 -40
  82. package/lib/browser-only/browser-only-filesystem-provider-server.d.ts +11 -11
  83. package/lib/browser-only/browser-only-filesystem-provider-server.js +39 -39
  84. package/lib/browser-only/browserfs-filesystem-initialization.d.ts +12 -12
  85. package/lib/browser-only/browserfs-filesystem-initialization.js +54 -54
  86. package/lib/browser-only/browserfs-filesystem-provider.d.ts +45 -45
  87. package/lib/browser-only/browserfs-filesystem-provider.js +439 -439
  88. package/lib/common/delegating-file-system-provider.d.ts +76 -76
  89. package/lib/common/delegating-file-system-provider.js +168 -168
  90. package/lib/common/download/file-download-data.d.ts +6 -6
  91. package/lib/common/download/file-download-data.js +26 -26
  92. package/lib/common/file-upload.d.ts +1 -1
  93. package/lib/common/file-upload.js +19 -19
  94. package/lib/common/files.d.ts +659 -659
  95. package/lib/common/files.js +355 -355
  96. package/lib/common/files.spec.d.ts +1 -1
  97. package/lib/common/files.spec.js +51 -51
  98. package/lib/common/filesystem-utils.d.ts +14 -14
  99. package/lib/common/filesystem-utils.js +63 -63
  100. package/lib/common/filesystem-utils.spec.d.ts +1 -1
  101. package/lib/common/filesystem-utils.spec.js +378 -378
  102. package/lib/common/filesystem-watcher-protocol.d.ts +71 -71
  103. package/lib/common/filesystem-watcher-protocol.js +20 -20
  104. package/lib/common/filesystem.d.ts +22 -22
  105. package/lib/common/filesystem.js +42 -42
  106. package/lib/common/index.d.ts +2 -2
  107. package/lib/common/index.js +20 -20
  108. package/lib/common/io.d.ts +19 -19
  109. package/lib/common/io.js +110 -110
  110. package/lib/common/remote-file-system-provider.d.ts +173 -173
  111. package/lib/common/remote-file-system-provider.js +435 -435
  112. package/lib/electron-browser/file-dialog/electron-file-dialog-module.d.ts +3 -3
  113. package/lib/electron-browser/file-dialog/electron-file-dialog-module.js +24 -24
  114. package/lib/electron-browser/file-dialog/electron-file-dialog-service.d.ts +19 -19
  115. package/lib/electron-browser/file-dialog/electron-file-dialog-service.js +148 -148
  116. package/lib/electron-browser/preload.d.ts +1 -1
  117. package/lib/electron-browser/preload.js +30 -30
  118. package/lib/electron-common/electron-api.d.ts +34 -34
  119. package/lib/electron-common/electron-api.js +20 -20
  120. package/lib/electron-main/electron-api-main.d.ts +5 -5
  121. package/lib/electron-main/electron-api-main.js +73 -73
  122. package/lib/electron-main/electron-main-module.d.ts +3 -3
  123. package/lib/electron-main/electron-main-module.js +24 -24
  124. package/lib/node/disk-file-system-provider.d.ts +72 -72
  125. package/lib/node/disk-file-system-provider.js +787 -787
  126. package/lib/node/disk-file-system-provider.spec.d.ts +1 -1
  127. package/lib/node/disk-file-system-provider.spec.js +122 -122
  128. package/lib/node/download/directory-archiver.d.ts +9 -9
  129. package/lib/node/download/directory-archiver.js +127 -127
  130. package/lib/node/download/directory-archiver.spec.d.ts +1 -1
  131. package/lib/node/download/directory-archiver.spec.js +97 -97
  132. package/lib/node/download/file-download-backend-module.d.ts +3 -3
  133. package/lib/node/download/file-download-backend-module.js +32 -32
  134. package/lib/node/download/file-download-cache.d.ts +21 -21
  135. package/lib/node/download/file-download-cache.js +82 -82
  136. package/lib/node/download/file-download-endpoint.d.ts +11 -11
  137. package/lib/node/download/file-download-endpoint.js +67 -67
  138. package/lib/node/download/file-download-handler.d.ts +50 -50
  139. package/lib/node/download/file-download-handler.js +307 -307
  140. package/lib/node/download/test/mock-directory-archiver.d.ts +7 -7
  141. package/lib/node/download/test/mock-directory-archiver.js +29 -29
  142. package/lib/node/file-change-collection.d.ts +22 -22
  143. package/lib/node/file-change-collection.js +77 -77
  144. package/lib/node/file-change-collection.spec.d.ts +1 -1
  145. package/lib/node/file-change-collection.spec.js +90 -90
  146. package/lib/node/filesystem-backend-module.d.ts +26 -26
  147. package/lib/node/filesystem-backend-module.js +120 -120
  148. package/lib/node/filesystem-watcher-client.d.ts +23 -23
  149. package/lib/node/filesystem-watcher-client.js +75 -75
  150. package/lib/node/filesystem-watcher-dispatcher.d.ts +23 -23
  151. package/lib/node/filesystem-watcher-dispatcher.js +80 -80
  152. package/lib/node/node-file-upload-service.d.ts +16 -16
  153. package/lib/node/node-file-upload-service.js +79 -79
  154. package/lib/node/nsfw-watcher/index.d.ts +3 -3
  155. package/lib/node/nsfw-watcher/index.js +39 -39
  156. package/lib/node/nsfw-watcher/nsfw-filesystem-service.d.ts +191 -191
  157. package/lib/node/nsfw-watcher/nsfw-filesystem-service.js +405 -405
  158. package/lib/node/nsfw-watcher/nsfw-filesystem-watcher.spec.d.ts +1 -1
  159. package/lib/node/nsfw-watcher/nsfw-filesystem-watcher.spec.js +151 -151
  160. package/lib/node/nsfw-watcher/nsfw-options.d.ts +6 -6
  161. package/lib/node/nsfw-watcher/nsfw-options.js +22 -22
  162. package/package.json +4 -4
  163. package/src/browser/breadcrumbs/filepath-breadcrumb.ts +43 -43
  164. package/src/browser/breadcrumbs/filepath-breadcrumbs-container.ts +65 -65
  165. package/src/browser/breadcrumbs/filepath-breadcrumbs-contribution.ts +129 -129
  166. package/src/browser/download/file-download-command-contribution.ts +83 -83
  167. package/src/browser/download/file-download-frontend-module.ts +25 -25
  168. package/src/browser/download/file-download-service.ts +179 -179
  169. package/src/browser/file-dialog/file-dialog-container.ts +67 -67
  170. package/src/browser/file-dialog/file-dialog-hidden-files-renderer.tsx +59 -59
  171. package/src/browser/file-dialog/file-dialog-model.ts +96 -96
  172. package/src/browser/file-dialog/file-dialog-module.ts +44 -44
  173. package/src/browser/file-dialog/file-dialog-service.ts +99 -99
  174. package/src/browser/file-dialog/file-dialog-tree-filters-renderer.tsx +100 -100
  175. package/src/browser/file-dialog/file-dialog-tree.ts +89 -89
  176. package/src/browser/file-dialog/file-dialog-widget.ts +75 -75
  177. package/src/browser/file-dialog/file-dialog.ts +434 -434
  178. package/src/browser/file-dialog/index.ts +20 -20
  179. package/src/browser/file-resource.ts +390 -390
  180. package/src/browser/file-selection.ts +44 -44
  181. package/src/browser/file-service.ts +1841 -1841
  182. package/src/browser/file-tree/file-tree-container.ts +36 -36
  183. package/src/browser/file-tree/file-tree-decorator-adapter.ts +159 -159
  184. package/src/browser/file-tree/file-tree-label-provider.ts +53 -53
  185. package/src/browser/file-tree/file-tree-model.ts +212 -212
  186. package/src/browser/file-tree/file-tree-widget.tsx +327 -327
  187. package/src/browser/file-tree/file-tree.ts +183 -183
  188. package/src/browser/file-tree/index.ts +22 -22
  189. package/src/browser/file-upload-service.ts +539 -539
  190. package/src/browser/filesystem-frontend-contribution.ts +381 -338
  191. package/src/browser/filesystem-frontend-module.ts +77 -77
  192. package/src/browser/filesystem-preferences.ts +139 -139
  193. package/src/browser/filesystem-save-resource-service.ts +125 -125
  194. package/src/browser/filesystem-watcher-error-handler.ts +60 -60
  195. package/src/browser/index.ts +21 -21
  196. package/src/browser/location/index.ts +18 -18
  197. package/src/browser/location/location-renderer.tsx +404 -404
  198. package/src/browser/location/location-service.ts +22 -22
  199. package/src/browser/remote-file-service-contribution.ts +38 -38
  200. package/src/browser/style/file-dialog.css +208 -208
  201. package/src/browser/style/file-icons.css +64 -64
  202. package/src/browser/style/filepath-breadcrumbs.css +20 -20
  203. package/src/browser/style/index.css +36 -36
  204. package/src/browser-only/browser-only-filesystem-frontend-module.ts +38 -38
  205. package/src/browser-only/browser-only-filesystem-provider-server.ts +32 -32
  206. package/src/browser-only/browserfs-filesystem-initialization.ts +61 -61
  207. package/src/browser-only/browserfs-filesystem-provider.ts +462 -462
  208. package/src/common/delegating-file-system-provider.ts +226 -226
  209. package/src/common/download/README.md +30 -30
  210. package/src/common/download/file-download-data.ts +27 -27
  211. package/src/common/file-upload.ts +17 -17
  212. package/src/common/files.spec.ts +51 -51
  213. package/src/common/files.ts +996 -996
  214. package/src/common/filesystem-utils.spec.ts +411 -411
  215. package/src/common/filesystem-utils.ts +64 -64
  216. package/src/common/filesystem-watcher-protocol.ts +96 -96
  217. package/src/common/filesystem.ts +43 -43
  218. package/src/common/index.ts +18 -18
  219. package/src/common/io.ts +150 -150
  220. package/src/common/remote-file-system-provider.ts +549 -549
  221. package/src/electron-browser/file-dialog/electron-file-dialog-module.ts +24 -24
  222. package/src/electron-browser/file-dialog/electron-file-dialog-service.ts +165 -165
  223. package/src/electron-browser/preload.ts +31 -31
  224. package/src/electron-common/electron-api.ts +55 -55
  225. package/src/electron-main/electron-api-main.ts +78 -78
  226. package/src/electron-main/electron-main-module.ts +23 -23
  227. package/src/node/disk-file-system-provider.spec.ts +142 -142
  228. package/src/node/disk-file-system-provider.ts +915 -915
  229. package/src/node/download/directory-archiver.spec.ts +104 -104
  230. package/src/node/download/directory-archiver.ts +126 -126
  231. package/src/node/download/file-download-backend-module.ts +32 -32
  232. package/src/node/download/file-download-cache.ts +88 -88
  233. package/src/node/download/file-download-endpoint.ts +63 -63
  234. package/src/node/download/file-download-handler.ts +304 -304
  235. package/src/node/download/test/mock-directory-archiver.ts +30 -30
  236. package/src/node/file-change-collection.spec.ts +110 -110
  237. package/src/node/file-change-collection.ts +78 -78
  238. package/src/node/filesystem-backend-module.ts +140 -140
  239. package/src/node/filesystem-watcher-client.ts +72 -72
  240. package/src/node/filesystem-watcher-dispatcher.ts +82 -82
  241. package/src/node/node-file-upload-service.ts +80 -80
  242. package/src/node/nsfw-watcher/index.ts +45 -45
  243. package/src/node/nsfw-watcher/nsfw-filesystem-service.ts +481 -481
  244. package/src/node/nsfw-watcher/nsfw-filesystem-watcher.spec.ts +182 -182
  245. package/src/node/nsfw-watcher/nsfw-options.ts +23 -23
  246. package/src/typings/dom.webkit.d.ts +77 -77
  247. package/src/typings/mv/index.d.ts +21 -21
  248. package/src/typings/nsfw/index.d.ts +18 -18
  249. package/src/typings/trash/index.d.ts +20 -20
@@ -1,64 +1,64 @@
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 { FileStat } from '../common/files';
18
- import URI from '@theia/core/lib/common/uri';
19
-
20
- export namespace FileSystemUtils {
21
- export const FILE_NAME_SEPARATOR = ' ';
22
-
23
- /**
24
- * Generate unique URI for a given parent which does not collide
25
- *
26
- * @param parent the `FileStat` of the parent
27
- * @param targetUri the initial URI
28
- * @param isDirectory indicates whether the given targetUri represents a directory
29
- * @param suffix an optional string to append to the file name, in case of collision (e.g. `copy`)
30
- */
31
- export function generateUniqueResourceURI(parent: FileStat, targetUri: URI, isDirectory: boolean, suffix?: string): URI {
32
- const children = !parent.children ? [] : parent.children!.map(child => child.resource);
33
- let name = targetUri.path.name;
34
- let extension = targetUri.path.ext;
35
- if (!name) {
36
- // special case for dotfiles (e.g. '.foobar'): use the extension as the name
37
- name = targetUri.path.ext;
38
- extension = '';
39
- }
40
- // we want the path base for directories with the source path `foo.bar` to be generated as `foo.bar copy` and not `foo copy.bar` as we do for files
41
- if (isDirectory) {
42
- name = name + extension;
43
- extension = '';
44
- }
45
-
46
- let base = name + extension;
47
- // test if the name already contains the suffix or the suffix + index, so we don't add it again
48
- const nameRegex = RegExp(`.*${FileSystemUtils.FILE_NAME_SEPARATOR}${suffix}(${FileSystemUtils.FILE_NAME_SEPARATOR}[0-9]*)?$`);
49
- if (suffix && !nameRegex.test(name) && children.some(child => child.path.base === base)) {
50
- name = name + FILE_NAME_SEPARATOR + suffix;
51
- base = name + extension;
52
- }
53
- if (suffix && nameRegex.test(name)) {
54
- // remove the existing index from the name, so we can generate a new one
55
- name = name.replace(RegExp(`${FILE_NAME_SEPARATOR}[0-9]*$`), '');
56
- }
57
- let index = 0;
58
- while (children.some(child => child.path.base === base)) {
59
- index = index + 1;
60
- base = name + FILE_NAME_SEPARATOR + index + extension;
61
- }
62
- return parent.resource.resolve(base);
63
- }
64
- }
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 { FileStat } from '../common/files';
18
+ import URI from '@theia/core/lib/common/uri';
19
+
20
+ export namespace FileSystemUtils {
21
+ export const FILE_NAME_SEPARATOR = ' ';
22
+
23
+ /**
24
+ * Generate unique URI for a given parent which does not collide
25
+ *
26
+ * @param parent the `FileStat` of the parent
27
+ * @param targetUri the initial URI
28
+ * @param isDirectory indicates whether the given targetUri represents a directory
29
+ * @param suffix an optional string to append to the file name, in case of collision (e.g. `copy`)
30
+ */
31
+ export function generateUniqueResourceURI(parent: FileStat, targetUri: URI, isDirectory: boolean, suffix?: string): URI {
32
+ const children = !parent.children ? [] : parent.children!.map(child => child.resource);
33
+ let name = targetUri.path.name;
34
+ let extension = targetUri.path.ext;
35
+ if (!name) {
36
+ // special case for dotfiles (e.g. '.foobar'): use the extension as the name
37
+ name = targetUri.path.ext;
38
+ extension = '';
39
+ }
40
+ // we want the path base for directories with the source path `foo.bar` to be generated as `foo.bar copy` and not `foo copy.bar` as we do for files
41
+ if (isDirectory) {
42
+ name = name + extension;
43
+ extension = '';
44
+ }
45
+
46
+ let base = name + extension;
47
+ // test if the name already contains the suffix or the suffix + index, so we don't add it again
48
+ const nameRegex = RegExp(`.*${FileSystemUtils.FILE_NAME_SEPARATOR}${suffix}(${FileSystemUtils.FILE_NAME_SEPARATOR}[0-9]*)?$`);
49
+ if (suffix && !nameRegex.test(name) && children.some(child => child.path.base === base)) {
50
+ name = name + FILE_NAME_SEPARATOR + suffix;
51
+ base = name + extension;
52
+ }
53
+ if (suffix && nameRegex.test(name)) {
54
+ // remove the existing index from the name, so we can generate a new one
55
+ name = name.replace(RegExp(`${FILE_NAME_SEPARATOR}[0-9]*$`), '');
56
+ }
57
+ let index = 0;
58
+ while (children.some(child => child.path.base === base)) {
59
+ index = index + 1;
60
+ base = name + FILE_NAME_SEPARATOR + index + extension;
61
+ }
62
+ return parent.resource.resolve(base);
63
+ }
64
+ }
@@ -1,96 +1,96 @@
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
- import { RpcServer } from '@theia/core';
18
- import { FileChangeType } from './files';
19
- export { FileChangeType };
20
-
21
- export const FileSystemWatcherService = Symbol('FileSystemWatcherServer2');
22
- /**
23
- * Singleton implementation of the watch server.
24
- *
25
- * Since multiple clients all make requests to this service, we need to track those individually via a `clientId`.
26
- */
27
- export interface FileSystemWatcherService extends RpcServer<FileSystemWatcherServiceClient> {
28
- /**
29
- * @param clientId arbitrary id used to identify a client.
30
- * @param uri the path to watch.
31
- * @param options optional parameters.
32
- * @returns promise to a unique `number` handle for this request.
33
- */
34
- watchFileChanges(clientId: number, uri: string, options?: WatchOptions): Promise<number>;
35
- /**
36
- * @param watcherId handle mapping to a previous `watchFileChanges` request.
37
- */
38
- unwatchFileChanges(watcherId: number): Promise<void>;
39
- }
40
-
41
- export interface FileSystemWatcherServiceClient {
42
- /** Listen for change events emitted by the watcher. */
43
- onDidFilesChanged(event: DidFilesChangedParams): void;
44
- /** The watcher can crash in certain conditions. */
45
- onError(event: FileSystemWatcherErrorParams): void;
46
- }
47
-
48
- export interface DidFilesChangedParams {
49
- /** Clients to route the events to. */
50
- clients?: number[];
51
- /** FileSystem changes that occurred. */
52
- changes: FileChange[];
53
- }
54
-
55
- export interface FileSystemWatcherErrorParams {
56
- /** Clients to route the events to. */
57
- clients: number[];
58
- /** The uri that originated the error. */
59
- uri: string;
60
- }
61
-
62
- export const FileSystemWatcherServer = Symbol('FileSystemWatcherServer');
63
- export interface FileSystemWatcherServer extends RpcServer<FileSystemWatcherClient> {
64
- /**
65
- * Start file watching for the given param.
66
- * Resolve when watching is started.
67
- * Return a watcher id.
68
- */
69
- watchFileChanges(uri: string, options?: WatchOptions): Promise<number>;
70
-
71
- /**
72
- * Stop file watching for the given id.
73
- * Resolve when watching is stopped.
74
- */
75
- unwatchFileChanges(watcherId: number): Promise<void>;
76
- }
77
-
78
- export interface FileSystemWatcherClient {
79
- /**
80
- * Notify when files under watched uris are changed.
81
- */
82
- onDidFilesChanged(event: DidFilesChangedParams): void;
83
-
84
- /**
85
- * Notify when unable to watch files because of Linux handle limit.
86
- */
87
- onError(): void;
88
- }
89
-
90
- export interface WatchOptions {
91
- ignored: string[];
92
- }
93
- export interface FileChange {
94
- uri: string;
95
- type: FileChangeType;
96
- }
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
+ import { RpcServer } from '@theia/core';
18
+ import { FileChangeType } from './files';
19
+ export { FileChangeType };
20
+
21
+ export const FileSystemWatcherService = Symbol('FileSystemWatcherServer2');
22
+ /**
23
+ * Singleton implementation of the watch server.
24
+ *
25
+ * Since multiple clients all make requests to this service, we need to track those individually via a `clientId`.
26
+ */
27
+ export interface FileSystemWatcherService extends RpcServer<FileSystemWatcherServiceClient> {
28
+ /**
29
+ * @param clientId arbitrary id used to identify a client.
30
+ * @param uri the path to watch.
31
+ * @param options optional parameters.
32
+ * @returns promise to a unique `number` handle for this request.
33
+ */
34
+ watchFileChanges(clientId: number, uri: string, options?: WatchOptions): Promise<number>;
35
+ /**
36
+ * @param watcherId handle mapping to a previous `watchFileChanges` request.
37
+ */
38
+ unwatchFileChanges(watcherId: number): Promise<void>;
39
+ }
40
+
41
+ export interface FileSystemWatcherServiceClient {
42
+ /** Listen for change events emitted by the watcher. */
43
+ onDidFilesChanged(event: DidFilesChangedParams): void;
44
+ /** The watcher can crash in certain conditions. */
45
+ onError(event: FileSystemWatcherErrorParams): void;
46
+ }
47
+
48
+ export interface DidFilesChangedParams {
49
+ /** Clients to route the events to. */
50
+ clients?: number[];
51
+ /** FileSystem changes that occurred. */
52
+ changes: FileChange[];
53
+ }
54
+
55
+ export interface FileSystemWatcherErrorParams {
56
+ /** Clients to route the events to. */
57
+ clients: number[];
58
+ /** The uri that originated the error. */
59
+ uri: string;
60
+ }
61
+
62
+ export const FileSystemWatcherServer = Symbol('FileSystemWatcherServer');
63
+ export interface FileSystemWatcherServer extends RpcServer<FileSystemWatcherClient> {
64
+ /**
65
+ * Start file watching for the given param.
66
+ * Resolve when watching is started.
67
+ * Return a watcher id.
68
+ */
69
+ watchFileChanges(uri: string, options?: WatchOptions): Promise<number>;
70
+
71
+ /**
72
+ * Stop file watching for the given id.
73
+ * Resolve when watching is stopped.
74
+ */
75
+ unwatchFileChanges(watcherId: number): Promise<void>;
76
+ }
77
+
78
+ export interface FileSystemWatcherClient {
79
+ /**
80
+ * Notify when files under watched uris are changed.
81
+ */
82
+ onDidFilesChanged(event: DidFilesChangedParams): void;
83
+
84
+ /**
85
+ * Notify when unable to watch files because of Linux handle limit.
86
+ */
87
+ onError(): void;
88
+ }
89
+
90
+ export interface WatchOptions {
91
+ ignored: string[];
92
+ }
93
+ export interface FileChange {
94
+ uri: string;
95
+ type: FileChangeType;
96
+ }
@@ -1,43 +1,43 @@
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 namespace FileAccess {
18
-
19
- export namespace Constants {
20
-
21
- /**
22
- * Flag indicating that the file is visible to the calling process.
23
- * This is useful for determining if a file exists, but says nothing about rwx permissions. Default if no mode is specified.
24
- */
25
- export const F_OK: number = 0;
26
-
27
- /**
28
- * Flag indicating that the file can be read by the calling process.
29
- */
30
- export const R_OK: number = 4;
31
-
32
- /**
33
- * Flag indicating that the file can be written by the calling process.
34
- */
35
- export const W_OK: number = 2;
36
-
37
- /**
38
- * Flag indicating that the file can be executed by the calling process.
39
- * This has no effect on Windows (will behave like `FileAccess.F_OK`).
40
- */
41
- export const X_OK: number = 1;
42
- }
43
- }
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 namespace FileAccess {
18
+
19
+ export namespace Constants {
20
+
21
+ /**
22
+ * Flag indicating that the file is visible to the calling process.
23
+ * This is useful for determining if a file exists, but says nothing about rwx permissions. Default if no mode is specified.
24
+ */
25
+ export const F_OK: number = 0;
26
+
27
+ /**
28
+ * Flag indicating that the file can be read by the calling process.
29
+ */
30
+ export const R_OK: number = 4;
31
+
32
+ /**
33
+ * Flag indicating that the file can be written by the calling process.
34
+ */
35
+ export const W_OK: number = 2;
36
+
37
+ /**
38
+ * Flag indicating that the file can be executed by the calling process.
39
+ * This has no effect on Windows (will behave like `FileAccess.F_OK`).
40
+ */
41
+ export const X_OK: number = 1;
42
+ }
43
+ }
@@ -1,18 +1,18 @@
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 * from './filesystem';
18
- export * from './filesystem-utils';
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 * from './filesystem';
18
+ export * from './filesystem-utils';