@theia/plugin-ext 1.18.0-next.d3501165 → 1.19.0

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 (273) hide show
  1. package/LICENSE +642 -0
  2. package/README.md +5 -0
  3. package/lib/common/arrays.d.ts +4 -0
  4. package/lib/common/arrays.d.ts.map +1 -1
  5. package/lib/common/arrays.js +9 -1
  6. package/lib/common/arrays.js.map +1 -1
  7. package/lib/common/connection.d.ts +1 -2
  8. package/lib/common/connection.d.ts.map +1 -1
  9. package/lib/common/connection.js.map +1 -1
  10. package/lib/common/plugin-api-rpc-model.d.ts +4 -0
  11. package/lib/common/plugin-api-rpc-model.d.ts.map +1 -1
  12. package/lib/common/plugin-api-rpc-model.js.map +1 -1
  13. package/lib/common/plugin-api-rpc.d.ts +29 -11
  14. package/lib/common/plugin-api-rpc.d.ts.map +1 -1
  15. package/lib/common/plugin-api-rpc.js +21 -1
  16. package/lib/common/plugin-api-rpc.js.map +1 -1
  17. package/lib/common/plugin-protocol.d.ts +1 -0
  18. package/lib/common/plugin-protocol.d.ts.map +1 -1
  19. package/lib/common/plugin-protocol.js.map +1 -1
  20. package/lib/hosted/browser/hosted-plugin.d.ts +5 -6
  21. package/lib/hosted/browser/hosted-plugin.d.ts.map +1 -1
  22. package/lib/hosted/browser/hosted-plugin.js +19 -13
  23. package/lib/hosted/browser/hosted-plugin.js.map +1 -1
  24. package/lib/hosted/browser/worker/debug-stub.d.ts.map +1 -1
  25. package/lib/hosted/browser/worker/debug-stub.js +1 -0
  26. package/lib/hosted/browser/worker/debug-stub.js.map +1 -1
  27. package/lib/hosted/node/hosted-plugin-deployer-handler.d.ts +1 -1
  28. package/lib/hosted/node/hosted-plugin-deployer-handler.d.ts.map +1 -1
  29. package/lib/hosted/node/hosted-plugin-deployer-handler.js +14 -38
  30. package/lib/hosted/node/hosted-plugin-deployer-handler.js.map +1 -1
  31. package/lib/hosted/node/hosted-plugin-localization-service.d.ts +37 -0
  32. package/lib/hosted/node/hosted-plugin-localization-service.d.ts.map +1 -0
  33. package/lib/hosted/node/hosted-plugin-localization-service.js +197 -0
  34. package/lib/hosted/node/hosted-plugin-localization-service.js.map +1 -0
  35. package/lib/hosted/node/hosted-plugin-process.d.ts +2 -2
  36. package/lib/hosted/node/hosted-plugin-process.d.ts.map +1 -1
  37. package/lib/hosted/node/hosted-plugin-process.js +5 -7
  38. package/lib/hosted/node/hosted-plugin-process.js.map +1 -1
  39. package/lib/hosted/node/plugin-ext-hosted-backend-module.d.ts.map +1 -1
  40. package/lib/hosted/node/plugin-ext-hosted-backend-module.js +2 -0
  41. package/lib/hosted/node/plugin-ext-hosted-backend-module.js.map +1 -1
  42. package/lib/hosted/node/plugin-manifest-loader.d.ts +1 -1
  43. package/lib/hosted/node/plugin-manifest-loader.d.ts.map +1 -1
  44. package/lib/hosted/node/plugin-manifest-loader.js +4 -52
  45. package/lib/hosted/node/plugin-manifest-loader.js.map +1 -1
  46. package/lib/hosted/node/plugin-service.d.ts +3 -6
  47. package/lib/hosted/node/plugin-service.d.ts.map +1 -1
  48. package/lib/hosted/node/plugin-service.js +7 -40
  49. package/lib/hosted/node/plugin-service.js.map +1 -1
  50. package/lib/hosted/node/scanners/scanner-theia.d.ts.map +1 -1
  51. package/lib/hosted/node/scanners/scanner-theia.js +3 -2
  52. package/lib/hosted/node/scanners/scanner-theia.js.map +1 -1
  53. package/lib/main/browser/callhierarchy/callhierarchy-type-converters.d.ts.map +1 -1
  54. package/lib/main/browser/callhierarchy/callhierarchy-type-converters.js +6 -2
  55. package/lib/main/browser/callhierarchy/callhierarchy-type-converters.js.map +1 -1
  56. package/lib/main/browser/custom-editors/custom-editor-opener.d.ts +2 -2
  57. package/lib/main/browser/custom-editors/custom-editor-opener.d.ts.map +1 -1
  58. package/lib/main/browser/custom-editors/custom-editor-opener.js +6 -2
  59. package/lib/main/browser/custom-editors/custom-editor-opener.js.map +1 -1
  60. package/lib/main/browser/custom-editors/custom-editors-main.d.ts.map +1 -1
  61. package/lib/main/browser/custom-editors/custom-editors-main.js +1 -2
  62. package/lib/main/browser/custom-editors/custom-editors-main.js.map +1 -1
  63. package/lib/main/browser/debug/debug-main.js +1 -1
  64. package/lib/main/browser/debug/debug-main.js.map +1 -1
  65. package/lib/main/browser/debug/plugin-debug-adapter-contribution.d.ts +1 -1
  66. package/lib/main/browser/debug/plugin-debug-adapter-contribution.d.ts.map +1 -1
  67. package/lib/main/browser/debug/plugin-debug-adapter-contribution.js +2 -2
  68. package/lib/main/browser/debug/plugin-debug-adapter-contribution.js.map +1 -1
  69. package/lib/main/browser/debug/plugin-debug-service.d.ts +8 -0
  70. package/lib/main/browser/debug/plugin-debug-service.d.ts.map +1 -1
  71. package/lib/main/browser/debug/plugin-debug-service.js +15 -0
  72. package/lib/main/browser/debug/plugin-debug-service.js.map +1 -1
  73. package/lib/main/browser/debug/plugin-debug-session-factory.d.ts +2 -2
  74. package/lib/main/browser/debug/plugin-debug-session-factory.d.ts.map +1 -1
  75. package/lib/main/browser/debug/plugin-debug-session-factory.js.map +1 -1
  76. package/lib/main/browser/dialogs/modal-notification.d.ts +4 -4
  77. package/lib/main/browser/dialogs/modal-notification.d.ts.map +1 -1
  78. package/lib/main/browser/dialogs/modal-notification.js +21 -10
  79. package/lib/main/browser/dialogs/modal-notification.js.map +1 -1
  80. package/lib/main/browser/editors-and-documents-main.d.ts.map +1 -1
  81. package/lib/main/browser/editors-and-documents-main.js +3 -4
  82. package/lib/main/browser/editors-and-documents-main.js.map +1 -1
  83. package/lib/main/browser/languages-main.js +1 -1
  84. package/lib/main/browser/languages-main.js.map +1 -1
  85. package/lib/main/browser/message-registry-main.js +1 -1
  86. package/lib/main/browser/message-registry-main.js.map +1 -1
  87. package/lib/main/browser/plugin-ext-frontend-module.d.ts.map +1 -1
  88. package/lib/main/browser/plugin-ext-frontend-module.js +5 -3
  89. package/lib/main/browser/plugin-ext-frontend-module.js.map +1 -1
  90. package/lib/main/browser/plugin-ext-widget.d.ts.map +1 -1
  91. package/lib/main/browser/plugin-ext-widget.js +3 -2
  92. package/lib/main/browser/plugin-ext-widget.js.map +1 -1
  93. package/lib/main/browser/plugin-shared-style.js +1 -1
  94. package/lib/main/browser/plugin-shared-style.js.map +1 -1
  95. package/lib/main/browser/quick-open-main.d.ts +3 -6
  96. package/lib/main/browser/quick-open-main.d.ts.map +1 -1
  97. package/lib/main/browser/quick-open-main.js +48 -100
  98. package/lib/main/browser/quick-open-main.js.map +1 -1
  99. package/lib/main/browser/timeline-main.d.ts.map +1 -1
  100. package/lib/main/browser/timeline-main.js +1 -1
  101. package/lib/main/browser/timeline-main.js.map +1 -1
  102. package/lib/main/browser/view/plugin-view-registry.d.ts +3 -2
  103. package/lib/main/browser/view/plugin-view-registry.d.ts.map +1 -1
  104. package/lib/main/browser/view/plugin-view-registry.js +64 -24
  105. package/lib/main/browser/view/plugin-view-registry.js.map +1 -1
  106. package/lib/main/browser/view/plugin-view-widget.d.ts +2 -0
  107. package/lib/main/browser/view/plugin-view-widget.d.ts.map +1 -1
  108. package/lib/main/browser/view/plugin-view-widget.js +3 -1
  109. package/lib/main/browser/view/plugin-view-widget.js.map +1 -1
  110. package/lib/main/browser/view/tree-view-widget.d.ts +3 -4
  111. package/lib/main/browser/view/tree-view-widget.d.ts.map +1 -1
  112. package/lib/main/browser/view/tree-view-widget.js +25 -28
  113. package/lib/main/browser/view/tree-view-widget.js.map +1 -1
  114. package/lib/main/browser/webview/webview-frontend-security-warnings.d.ts.map +1 -1
  115. package/lib/main/browser/webview/webview-frontend-security-warnings.js +8 -5
  116. package/lib/main/browser/webview/webview-frontend-security-warnings.js.map +1 -1
  117. package/lib/main/browser/webview/webview-preferences.d.ts.map +1 -1
  118. package/lib/main/browser/webview/webview-preferences.js +3 -2
  119. package/lib/main/browser/webview/webview-preferences.js.map +1 -1
  120. package/lib/main/browser/webview/webview.d.ts +1 -1
  121. package/lib/main/browser/webview/webview.d.ts.map +1 -1
  122. package/lib/main/browser/webview/webview.js +2 -2
  123. package/lib/main/browser/webview/webview.js.map +1 -1
  124. package/lib/plugin/comments.d.ts.map +1 -1
  125. package/lib/plugin/comments.js +2 -3
  126. package/lib/plugin/comments.js.map +1 -1
  127. package/lib/plugin/custom-editors.d.ts +1 -2
  128. package/lib/plugin/custom-editors.d.ts.map +1 -1
  129. package/lib/plugin/custom-editors.js +2 -3
  130. package/lib/plugin/custom-editors.js.map +1 -1
  131. package/lib/plugin/decorations.d.ts.map +1 -1
  132. package/lib/plugin/decorations.js +2 -3
  133. package/lib/plugin/decorations.js.map +1 -1
  134. package/lib/plugin/document-data.d.ts.map +1 -1
  135. package/lib/plugin/document-data.js +1 -1
  136. package/lib/plugin/document-data.js.map +1 -1
  137. package/lib/plugin/documents.d.ts.map +1 -1
  138. package/lib/plugin/documents.js +1 -2
  139. package/lib/plugin/documents.js.map +1 -1
  140. package/lib/plugin/file-system-event-service-ext-impl.d.ts.map +1 -1
  141. package/lib/plugin/file-system-event-service-ext-impl.js +2 -3
  142. package/lib/plugin/file-system-event-service-ext-impl.js.map +1 -1
  143. package/lib/plugin/file-system-ext-impl.d.ts.map +1 -1
  144. package/lib/plugin/file-system-ext-impl.js +12 -13
  145. package/lib/plugin/file-system-ext-impl.js.map +1 -1
  146. package/lib/plugin/known-commands.spec.js +1 -2
  147. package/lib/plugin/known-commands.spec.js.map +1 -1
  148. package/lib/plugin/languages/call-hierarchy.d.ts +1 -1
  149. package/lib/plugin/languages/call-hierarchy.d.ts.map +1 -1
  150. package/lib/plugin/languages/call-hierarchy.js +8 -3
  151. package/lib/plugin/languages/call-hierarchy.js.map +1 -1
  152. package/lib/plugin/languages/rename.d.ts +1 -2
  153. package/lib/plugin/languages/rename.d.ts.map +1 -1
  154. package/lib/plugin/languages/rename.js.map +1 -1
  155. package/lib/plugin/languages.d.ts +1 -1
  156. package/lib/plugin/languages.d.ts.map +1 -1
  157. package/lib/plugin/languages.js +2 -1
  158. package/lib/plugin/languages.js.map +1 -1
  159. package/lib/plugin/message-registry.d.ts.map +1 -1
  160. package/lib/plugin/message-registry.js +8 -5
  161. package/lib/plugin/message-registry.js.map +1 -1
  162. package/lib/plugin/node/debug/debug.d.ts +4 -3
  163. package/lib/plugin/node/debug/debug.d.ts.map +1 -1
  164. package/lib/plugin/node/debug/debug.js +34 -15
  165. package/lib/plugin/node/debug/debug.js.map +1 -1
  166. package/lib/plugin/node/debug/plugin-debug-adapter-session.d.ts +3 -3
  167. package/lib/plugin/node/debug/plugin-debug-adapter-session.d.ts.map +1 -1
  168. package/lib/plugin/node/debug/plugin-debug-adapter-session.js.map +1 -1
  169. package/lib/plugin/node/debug/plugin-debug-adapter-starter.d.ts +6 -4
  170. package/lib/plugin/node/debug/plugin-debug-adapter-starter.d.ts.map +1 -1
  171. package/lib/plugin/node/debug/plugin-debug-adapter-starter.js +23 -13
  172. package/lib/plugin/node/debug/plugin-debug-adapter-starter.js.map +1 -1
  173. package/lib/plugin/plugin-context.d.ts.map +1 -1
  174. package/lib/plugin/plugin-context.js +8 -3
  175. package/lib/plugin/plugin-context.js.map +1 -1
  176. package/lib/plugin/plugin-manager.d.ts +2 -0
  177. package/lib/plugin/plugin-manager.d.ts.map +1 -1
  178. package/lib/plugin/plugin-manager.js +24 -3
  179. package/lib/plugin/plugin-manager.js.map +1 -1
  180. package/lib/plugin/plugin-storage.d.ts +4 -0
  181. package/lib/plugin/plugin-storage.d.ts.map +1 -1
  182. package/lib/plugin/plugin-storage.js +6 -1
  183. package/lib/plugin/plugin-storage.js.map +1 -1
  184. package/lib/plugin/preference-registry.spec.js.map +1 -1
  185. package/lib/plugin/quick-open.d.ts +1 -3
  186. package/lib/plugin/quick-open.d.ts.map +1 -1
  187. package/lib/plugin/quick-open.js +10 -25
  188. package/lib/plugin/quick-open.js.map +1 -1
  189. package/lib/plugin/tasks/tasks.d.ts +1 -1
  190. package/lib/plugin/tasks/tasks.d.ts.map +1 -1
  191. package/lib/plugin/tasks/tasks.js +3 -2
  192. package/lib/plugin/tasks/tasks.js.map +1 -1
  193. package/lib/plugin/timeline.d.ts.map +1 -1
  194. package/lib/plugin/timeline.js +1 -2
  195. package/lib/plugin/timeline.js.map +1 -1
  196. package/lib/plugin/type-converters.d.ts.map +1 -1
  197. package/lib/plugin/type-converters.js +18 -11
  198. package/lib/plugin/type-converters.js.map +1 -1
  199. package/lib/plugin/types-impl.d.ts +55 -1
  200. package/lib/plugin/types-impl.d.ts.map +1 -1
  201. package/lib/plugin/types-impl.js +81 -1
  202. package/lib/plugin/types-impl.js.map +1 -1
  203. package/lib/plugin/webviews.d.ts +1 -2
  204. package/lib/plugin/webviews.d.ts.map +1 -1
  205. package/lib/plugin/webviews.js.map +1 -1
  206. package/package.json +31 -27
  207. package/src/common/arrays.ts +8 -0
  208. package/src/common/connection.ts +1 -2
  209. package/src/common/plugin-api-rpc-model.ts +4 -0
  210. package/src/common/plugin-api-rpc.ts +31 -10
  211. package/src/common/plugin-protocol.ts +2 -0
  212. package/src/hosted/browser/hosted-plugin.ts +19 -12
  213. package/src/hosted/browser/worker/debug-stub.ts +1 -0
  214. package/src/hosted/node/hosted-plugin-deployer-handler.ts +13 -40
  215. package/src/hosted/node/hosted-plugin-localization-service.ts +201 -0
  216. package/src/hosted/node/hosted-plugin-process.ts +4 -6
  217. package/src/hosted/node/plugin-ext-hosted-backend-module.ts +2 -0
  218. package/src/hosted/node/plugin-manifest-loader.ts +4 -56
  219. package/src/hosted/node/plugin-service.ts +7 -40
  220. package/src/hosted/node/scanners/scanner-theia.ts +4 -2
  221. package/src/main/browser/callhierarchy/callhierarchy-type-converters.ts +6 -2
  222. package/src/main/browser/custom-editors/custom-editor-opener.tsx +8 -4
  223. package/src/main/browser/custom-editors/custom-editors-main.ts +1 -2
  224. package/src/main/browser/debug/debug-main.ts +1 -1
  225. package/src/main/browser/debug/plugin-debug-adapter-contribution.ts +3 -3
  226. package/src/main/browser/debug/plugin-debug-service.ts +23 -0
  227. package/src/main/browser/debug/plugin-debug-session-factory.ts +3 -3
  228. package/src/main/browser/dialogs/modal-notification.ts +24 -13
  229. package/src/main/browser/dialogs/style/modal-notification.css +17 -2
  230. package/src/main/browser/editors-and-documents-main.ts +1 -2
  231. package/src/main/browser/languages-main.ts +1 -1
  232. package/src/main/browser/message-registry-main.ts +1 -1
  233. package/src/main/browser/plugin-ext-frontend-module.ts +6 -4
  234. package/src/main/browser/plugin-ext-widget.tsx +3 -2
  235. package/src/main/browser/plugin-shared-style.ts +1 -1
  236. package/src/main/browser/quick-open-main.ts +54 -109
  237. package/src/main/browser/style/index.css +1 -5
  238. package/src/main/browser/style/plugin-sidebar.css +1 -1
  239. package/src/main/browser/timeline-main.ts +1 -2
  240. package/src/main/browser/view/plugin-view-registry.ts +68 -26
  241. package/src/main/browser/view/plugin-view-widget.ts +7 -2
  242. package/src/main/browser/view/tree-view-widget.tsx +41 -46
  243. package/src/main/browser/webview/pre/host.js +20 -12
  244. package/src/main/browser/webview/pre/main.js +1 -2
  245. package/src/main/browser/webview/pre/service-worker.js +1 -1
  246. package/src/main/browser/webview/webview-frontend-security-warnings.ts +8 -7
  247. package/src/main/browser/webview/webview-preferences.ts +3 -2
  248. package/src/main/browser/webview/webview.ts +2 -2
  249. package/src/plugin/comments.ts +1 -2
  250. package/src/plugin/custom-editors.ts +2 -4
  251. package/src/plugin/decorations.ts +1 -2
  252. package/src/plugin/document-data.ts +1 -2
  253. package/src/plugin/documents.ts +1 -2
  254. package/src/plugin/file-system-event-service-ext-impl.ts +1 -2
  255. package/src/plugin/file-system-ext-impl.ts +1 -2
  256. package/src/plugin/known-commands.spec.ts +1 -2
  257. package/src/plugin/languages/call-hierarchy.ts +14 -5
  258. package/src/plugin/languages/rename.ts +1 -2
  259. package/src/plugin/languages.ts +5 -2
  260. package/src/plugin/message-registry.ts +9 -6
  261. package/src/plugin/node/debug/debug.ts +40 -19
  262. package/src/plugin/node/debug/plugin-debug-adapter-session.ts +3 -3
  263. package/src/plugin/node/debug/plugin-debug-adapter-starter.ts +24 -14
  264. package/src/plugin/plugin-context.ts +21 -10
  265. package/src/plugin/plugin-manager.ts +26 -4
  266. package/src/plugin/plugin-storage.ts +7 -2
  267. package/src/plugin/preference-registry.spec.ts +1 -2
  268. package/src/plugin/quick-open.ts +12 -29
  269. package/src/plugin/tasks/tasks.ts +3 -2
  270. package/src/plugin/timeline.ts +1 -2
  271. package/src/plugin/type-converters.ts +20 -13
  272. package/src/plugin/types-impl.ts +77 -1
  273. package/src/plugin/webviews.ts +1 -2
@@ -23,6 +23,7 @@ import { IJSONSchema, IJSONSchemaSnippet } from '@theia/core/lib/common/json-sch
23
23
  import { RecursivePartial } from '@theia/core/lib/common/types';
24
24
  import { PreferenceSchema, PreferenceSchemaProperties } from '@theia/core/lib/common/preferences/preference-schema';
25
25
  import { ProblemMatcherContribution, ProblemPatternContribution, TaskDefinition } from '@theia/task/lib/common';
26
+ // eslint-disable-next-line @theia/runtime-import-check
26
27
  import { ColorDefinition } from '@theia/core/lib/browser/color-registry';
27
28
  import { ResourceLabelFormatter } from '@theia/core/lib/common/label-protocol';
28
29
 
@@ -554,6 +555,7 @@ export interface Localization {
554
555
 
555
556
  export interface Translation {
556
557
  id: string;
558
+ path: string;
557
559
  version: string;
558
560
  contents: { [scope: string]: { [key: string]: string } }
559
561
  }
@@ -25,13 +25,13 @@ import debounce = require('@theia/core/shared/lodash.debounce');
25
25
  import { UUID } from '@theia/core/shared/@phosphor/coreutils';
26
26
  import { injectable, inject, interfaces, named, postConstruct } from '@theia/core/shared/inversify';
27
27
  import { PluginWorker } from './plugin-worker';
28
- import { PluginMetadata, getPluginId, HostedPluginServer, DeployedPlugin } from '../../common/plugin-protocol';
28
+ import { PluginMetadata, getPluginId, HostedPluginServer, DeployedPlugin, PluginServer } from '../../common/plugin-protocol';
29
29
  import { HostedPluginWatcher } from './hosted-plugin-watcher';
30
30
  import { MAIN_RPC_CONTEXT, PluginManagerExt, ConfigStorage, UIKind } from '../../common/plugin-api-rpc';
31
31
  import { setUpPluginApi } from '../../main/browser/main-context';
32
32
  import { RPCProtocol, RPCProtocolImpl } from '../../common/rpc-protocol';
33
33
  import {
34
- Disposable, DisposableCollection,
34
+ Disposable, DisposableCollection, Emitter, isCancelled,
35
35
  ILogger, ContributionProvider, CommandRegistry, WillExecuteCommandEvent,
36
36
  CancellationTokenSource, JsonRpcProxy, ProgressService
37
37
  } from '@theia/core';
@@ -42,13 +42,11 @@ import { getQueryParameters } from '../../main/browser/env-main';
42
42
  import { MainPluginApiProvider } from '../../common/plugin-ext-api-contribution';
43
43
  import { PluginPathsService } from '../../main/common/plugin-paths-protocol';
44
44
  import { getPreferences } from '../../main/browser/preference-registry-main';
45
- import { PluginServer } from '../../common/plugin-protocol';
46
45
  import { Deferred } from '@theia/core/lib/common/promise-util';
47
46
  import { DebugSessionManager } from '@theia/debug/lib/browser/debug-session-manager';
48
47
  import { DebugConfigurationManager } from '@theia/debug/lib/browser/debug-configuration-manager';
49
48
  import { WaitUntilEvent } from '@theia/core/lib/common/event';
50
49
  import { FileSearchService } from '@theia/file-search/lib/common/file-search-service';
51
- import { Emitter, isCancelled } from '@theia/core';
52
50
  import { FrontendApplicationStateService } from '@theia/core/lib/browser/frontend-application-state';
53
51
  import { PluginViewRegistry } from '../../main/browser/view/plugin-view-registry';
54
52
  import { TaskProviderRegistry, TaskResolverRegistry } from '@theia/task/lib/browser/task-contribution';
@@ -66,7 +64,7 @@ import { PluginCustomEditorRegistry } from '../../main/browser/custom-editors/pl
66
64
  import { CustomEditorWidget } from '../../main/browser/custom-editors/custom-editor-widget';
67
65
 
68
66
  export type PluginHost = 'frontend' | string;
69
- export type DebugActivationEvent = 'onDebugResolve' | 'onDebugInitialConfigurations' | 'onDebugAdapterProtocolTracker';
67
+ export type DebugActivationEvent = 'onDebugResolve' | 'onDebugInitialConfigurations' | 'onDebugAdapterProtocolTracker' | 'onDebugDynamicConfigurations';
70
68
 
71
69
  export const PluginProgressLocation = 'plugin';
72
70
 
@@ -198,6 +196,8 @@ export class HostedPluginSupport {
198
196
  this.debugSessionManager.onWillStartDebugSession(event => this.ensureDebugActivation(event));
199
197
  this.debugSessionManager.onWillResolveDebugConfiguration(event => this.ensureDebugActivation(event, 'onDebugResolve', event.debugType));
200
198
  this.debugConfigurationManager.onWillProvideDebugConfiguration(event => this.ensureDebugActivation(event, 'onDebugInitialConfigurations'));
199
+ // Activate all providers of dynamic configurations, i.e. Let the user pick a configuration from all the available ones.
200
+ this.debugConfigurationManager.onWillProvideDynamicDebugConfiguration(event => this.ensureDebugActivation(event, 'onDebugDynamicConfigurations', '*'));
201
201
  this.viewRegistry.onDidExpandView(id => this.activateByView(id));
202
202
  this.taskProviderRegistry.onWillProvideTaskProvider(event => this.ensureTaskActivation(event));
203
203
  this.taskResolverRegistry.onWillProvideTaskResolver(event => this.ensureTaskActivation(event));
@@ -302,12 +302,15 @@ export class HostedPluginSupport {
302
302
  */
303
303
  protected async syncPlugins(): Promise<void> {
304
304
  let initialized = 0;
305
- const syncPluginsMeasurement = this.createMeasurement('syncPlugins');
305
+ const waitPluginsMeasurement = this.createMeasurement('waitForDeployment');
306
+ let syncPluginsMeasurement: () => number;
306
307
 
307
308
  const toUnload = new Set(this.contributions.keys());
308
309
  try {
309
310
  const pluginIds: string[] = [];
310
311
  const deployedPluginIds = await this.server.getDeployedPluginIds();
312
+ this.logMeasurement('Waiting for backend deployment', waitPluginsMeasurement);
313
+ syncPluginsMeasurement = this.createMeasurement('syncPlugins');
311
314
  for (const pluginId of deployedPluginIds) {
312
315
  toUnload.delete(pluginId);
313
316
  if (!this.contributions.has(pluginId)) {
@@ -336,7 +339,7 @@ export class HostedPluginSupport {
336
339
  }
337
340
  }
338
341
 
339
- this.logMeasurement('Sync', initialized, syncPluginsMeasurement);
342
+ this.logMeasurement(`Sync of ${this.getPluginCount(initialized)}`, syncPluginsMeasurement);
340
343
  }
341
344
 
342
345
  /**
@@ -374,7 +377,7 @@ export class HostedPluginSupport {
374
377
  }
375
378
  }
376
379
 
377
- this.logMeasurement('Load contributions', loaded, loadPluginsMeasurement);
380
+ this.logMeasurement(`Load contributions of ${this.getPluginCount(loaded)}`, loadPluginsMeasurement);
378
381
 
379
382
  return hostContributions;
380
383
  }
@@ -444,7 +447,7 @@ export class HostedPluginSupport {
444
447
  return;
445
448
  }
446
449
 
447
- this.logMeasurement('Start', started, startPluginsMeasurement);
450
+ this.logMeasurement(`Start of ${this.getPluginCount(started)}`, startPluginsMeasurement);
448
451
  }
449
452
 
450
453
  protected async obtainManager(host: string, hostContributions: PluginContributions[], toDisconnect: DisposableCollection): Promise<PluginManagerExt | undefined> {
@@ -712,15 +715,19 @@ export class HostedPluginSupport {
712
715
  };
713
716
  }
714
717
 
715
- protected logMeasurement(prefix: string, count: number, measurement: () => number): void {
718
+ protected logMeasurement(measurementName: string, measurement: () => number): void {
716
719
  const duration = measurement();
717
720
  if (duration === Number.NaN) {
718
721
  // Measurement was prevented by native API, do not log NaN duration
719
722
  return;
720
723
  }
721
724
 
722
- const pluginCount = `${count} plugin${count === 1 ? '' : 's'}`;
723
- console.log(`[${this.clientId}] ${prefix} of ${pluginCount} took: ${duration.toFixed(1)} ms`);
725
+ const timeFromFrontendStart = `Finished ${(performance.now() / 1000).toFixed(3)} s after frontend start`;
726
+ console.log(`[${this.clientId}] ${measurementName} took: ${duration.toFixed(1)} ms [${timeFromFrontendStart}]`);
727
+ }
728
+
729
+ protected getPluginCount(plugins: number): string {
730
+ return `${plugins} plugin${plugins === 1 ? '' : 's'}`;
724
731
  }
725
732
 
726
733
  protected readonly webviewsToRestore = new Set<WebviewWidget>();
@@ -14,6 +14,7 @@
14
14
  * SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
15
15
  ********************************************************************************/
16
16
 
17
+ // eslint-disable-next-line @theia/runtime-import-check
17
18
  import { DebugExtImpl } from '../../../plugin/node/debug/debug';
18
19
  import { RPCProtocol } from '../../../common/rpc-protocol';
19
20
 
@@ -17,11 +17,11 @@
17
17
  import * as fs from '@theia/core/shared/fs-extra';
18
18
  import { injectable, inject } from '@theia/core/shared/inversify';
19
19
  import { ILogger } from '@theia/core';
20
- import { PluginDeployerHandler, PluginDeployerEntry, PluginEntryPoint, DeployedPlugin, PluginDependencies, Localization } from '../../common/plugin-protocol';
20
+ import { PluginDeployerHandler, PluginDeployerEntry, PluginEntryPoint, DeployedPlugin, PluginDependencies, PluginType } from '../../common/plugin-protocol';
21
21
  import { HostedPluginReader } from './plugin-reader';
22
22
  import { Deferred } from '@theia/core/lib/common/promise-util';
23
- import { LocalizationProvider } from '@theia/core/lib/node/i18n/localization-provider';
24
- import { Localization as TheiaLocalization } from '@theia/core/lib/common/i18n/localization';
23
+ import { HostedPluginLocalizationService } from './hosted-plugin-localization-service';
24
+ import { BackendApplicationConfigProvider } from '@theia/core/lib/node/backend-application-config-provider';
25
25
 
26
26
  @injectable()
27
27
  export class HostedPluginDeployerHandler implements PluginDeployerHandler {
@@ -32,8 +32,8 @@ export class HostedPluginDeployerHandler implements PluginDeployerHandler {
32
32
  @inject(HostedPluginReader)
33
33
  private readonly reader: HostedPluginReader;
34
34
 
35
- @inject(LocalizationProvider)
36
- private readonly localizationProvider: LocalizationProvider;
35
+ @inject(HostedPluginLocalizationService)
36
+ private readonly localizationService: HostedPluginLocalizationService;
37
37
 
38
38
  private readonly deployedLocations = new Map<string, Set<string>>();
39
39
 
@@ -85,7 +85,11 @@ export class HostedPluginDeployerHandler implements PluginDeployerHandler {
85
85
  }
86
86
  const metadata = this.reader.readMetadata(manifest);
87
87
  const dependencies: PluginDependencies = { metadata };
88
- dependencies.mapping = this.reader.readDependencies(manifest);
88
+ // Do not resolve system (aka builtin) plugins because it should be done statically at build time.
89
+ const { resolveSystemPlugins = true } = BackendApplicationConfigProvider.get();
90
+ if (resolveSystemPlugins || entry.type !== PluginType.System) {
91
+ dependencies.mapping = this.reader.readDependencies(manifest);
92
+ }
89
93
  return dependencies;
90
94
  } catch (e) {
91
95
  console.error(`Failed to load plugin dependencies from '${pluginPath}' path`, e);
@@ -105,6 +109,8 @@ export class HostedPluginDeployerHandler implements PluginDeployerHandler {
105
109
  for (const plugin of backendPlugins) {
106
110
  await this.deployPlugin(plugin, 'backend');
107
111
  }
112
+ // rebuild translation config after deployment
113
+ this.localizationService.buildTranslationConfig([...this.deployedBackendPlugins.values()]);
108
114
  // resolve on first deploy
109
115
  this.backendPluginsMetadataDeferred.resolve(undefined);
110
116
  }
@@ -134,9 +140,7 @@ export class HostedPluginDeployerHandler implements PluginDeployerHandler {
134
140
  const { type } = entry;
135
141
  const deployed: DeployedPlugin = { metadata, type };
136
142
  deployed.contributes = this.reader.readContribution(manifest);
137
- if (deployed.contributes?.localizations) {
138
- this.localizationProvider.addLocalizations(...buildTheiaLocalizations(deployed.contributes.localizations));
139
- }
143
+ this.localizationService.deployLocalizations(deployed);
140
144
  deployedPlugins.set(metadata.model.id, deployed);
141
145
  this.logger.info(`Deploying ${entryPoint} plugin "${metadata.model.name}@${metadata.model.version}" from "${metadata.model.entryPoint[entryPoint] || pluginPath}"`);
142
146
  } catch (e) {
@@ -162,34 +166,3 @@ export class HostedPluginDeployerHandler implements PluginDeployerHandler {
162
166
  return true;
163
167
  }
164
168
  }
165
-
166
- function buildTheiaLocalizations(localizations: Localization[]): TheiaLocalization[] {
167
- const theiaLocalizations: TheiaLocalization[] = [];
168
- for (const localization of localizations) {
169
- const theiaLocalization: TheiaLocalization = {
170
- languageId: localization.languageId,
171
- languageName: localization.languageName,
172
- localizedLanguageName: localization.localizedLanguageName,
173
- languagePack: true,
174
- translations: {}
175
- };
176
- for (const translation of localization.translations) {
177
- for (const [scope, value] of Object.entries(translation.contents)) {
178
- for (const [key, item] of Object.entries(value)) {
179
- const translationKey = buildTheiaTranslationKey(translation.id, scope, key);
180
- theiaLocalization.translations[translationKey] = item;
181
- }
182
- }
183
- }
184
- theiaLocalizations.push(theiaLocalization);
185
- }
186
- return theiaLocalizations;
187
- }
188
-
189
- function buildTheiaTranslationKey(pluginId: string, scope: string, key: string): string {
190
- const scopeSlashIndex = scope.lastIndexOf('/');
191
- if (scopeSlashIndex >= 0) {
192
- scope = scope.substring(scopeSlashIndex + 1);
193
- }
194
- return `${pluginId}/${scope}/${key}`;
195
- }
@@ -0,0 +1,201 @@
1
+ /********************************************************************************
2
+ * Copyright (C) 2021 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 WITH Classpath-exception-2.0
15
+ ********************************************************************************/
16
+
17
+ import * as path from 'path';
18
+ import * as fs from '@theia/core/shared/fs-extra';
19
+ import { LocalizationProvider } from '@theia/core/lib/node/i18n/localization-provider';
20
+ import { Localization } from '@theia/core/lib/common/i18n/localization';
21
+ import { inject, injectable } from '@theia/core/shared/inversify';
22
+ import { DeployedPlugin, Localization as PluginLocalization, PluginContribution } from '../../common';
23
+ import { URI } from '@theia/core/shared/vscode-uri';
24
+ import { EnvVariablesServer } from '@theia/core/lib/common/env-variables';
25
+
26
+ export interface VSCodeNlsConfig {
27
+ locale: string
28
+ availableLanguages: Record<string, string>
29
+ _languagePackSupport?: boolean
30
+ _languagePackId?: string
31
+ _translationsConfigFile?: string
32
+ _cacheRoot?: string
33
+ _corruptedFile?: string
34
+ }
35
+
36
+ @injectable()
37
+ export class HostedPluginLocalizationService {
38
+
39
+ @inject(LocalizationProvider)
40
+ protected readonly localizationProvider: LocalizationProvider;
41
+
42
+ @inject(EnvVariablesServer)
43
+ protected readonly envVariables: EnvVariablesServer;
44
+
45
+ protected translationConfigFiles: Map<string, string> = new Map();
46
+
47
+ deployLocalizations(plugin: DeployedPlugin): void {
48
+ if (plugin.contributes?.localizations) {
49
+ this.localizationProvider.addLocalizations(...buildLocalizations(plugin.contributes.localizations));
50
+ }
51
+ }
52
+
53
+ async localizePlugin(plugin: DeployedPlugin): Promise<DeployedPlugin> {
54
+ const currentLanguage = this.localizationProvider.getCurrentLanguage();
55
+ const localization = this.localizationProvider.loadLocalization(currentLanguage);
56
+ const pluginPath = URI.parse(plugin.metadata.model.packageUri).fsPath;
57
+ const pluginId = plugin.metadata.model.id;
58
+ // create a shallow copy to not override the original plugin's contributes property.
59
+ const shallowCopy = { ...plugin };
60
+ try {
61
+ const translations = await loadPackageTranslations(pluginPath, currentLanguage);
62
+ shallowCopy.contributes = localizePackage(shallowCopy.contributes, translations, (key, original) => {
63
+ const fullKey = `${pluginId}/package/${key}`;
64
+ return Localization.localize(localization, fullKey, original);
65
+ }) as PluginContribution;
66
+ } catch (err) {
67
+ console.error(`Failed to localize plugin '${pluginId}'.`, err);
68
+ }
69
+ return shallowCopy;
70
+ }
71
+
72
+ getNlsConfig(): VSCodeNlsConfig {
73
+ const locale = this.localizationProvider.getCurrentLanguage();
74
+ const configFile = this.translationConfigFiles.get(locale);
75
+ if (locale === 'en' || !configFile) {
76
+ return { locale, availableLanguages: {} };
77
+ }
78
+ const cache = path.dirname(configFile);
79
+ return {
80
+ locale,
81
+ availableLanguages: { '*': locale },
82
+ _languagePackSupport: true,
83
+ _cacheRoot: cache,
84
+ _languagePackId: locale,
85
+ _translationsConfigFile: configFile
86
+ };
87
+ }
88
+
89
+ async buildTranslationConfig(plugins: DeployedPlugin[]): Promise<void> {
90
+ const configDir = URI.parse(await this.envVariables.getConfigDirUri()).fsPath;
91
+ const cacheDir = path.join(configDir, 'localization-cache');
92
+ const configs = new Map<string, Record<string, string>>();
93
+ for (const plugin of plugins) {
94
+ if (plugin.contributes?.localizations) {
95
+ const pluginPath = URI.parse(plugin.metadata.model.packageUri).fsPath;
96
+ for (const localization of plugin.contributes.localizations) {
97
+ const config = configs.get(localization.languageId) || {};
98
+ for (const translation of localization.translations) {
99
+ const fullPath = path.join(pluginPath, translation.path);
100
+ config[translation.id] = fullPath;
101
+ }
102
+ configs.set(localization.languageId, config);
103
+ }
104
+ }
105
+ }
106
+
107
+ for (const [language, config] of configs.entries()) {
108
+ const languageConfigDir = path.join(cacheDir, language);
109
+ await fs.mkdirs(languageConfigDir);
110
+ const configFile = path.join(languageConfigDir, `nls.config.${language}.json`);
111
+ this.translationConfigFiles.set(language, configFile);
112
+ await fs.writeJson(configFile, config);
113
+ }
114
+ }
115
+ }
116
+
117
+ function buildLocalizations(localizations: PluginLocalization[]): Localization[] {
118
+ const theiaLocalizations: Localization[] = [];
119
+ for (const localization of localizations) {
120
+ const theiaLocalization: Localization = {
121
+ languageId: localization.languageId,
122
+ languageName: localization.languageName,
123
+ localizedLanguageName: localization.localizedLanguageName,
124
+ languagePack: true,
125
+ translations: {}
126
+ };
127
+ for (const translation of localization.translations) {
128
+ for (const [scope, value] of Object.entries(translation.contents)) {
129
+ for (const [key, item] of Object.entries(value)) {
130
+ const translationKey = buildTranslationKey(translation.id, scope, key);
131
+ theiaLocalization.translations[translationKey] = item;
132
+ }
133
+ }
134
+ }
135
+ theiaLocalizations.push(theiaLocalization);
136
+ }
137
+ return theiaLocalizations;
138
+ }
139
+
140
+ function buildTranslationKey(pluginId: string, scope: string, key: string): string {
141
+ return `${pluginId}/${Localization.transformKey(scope)}/${key}`;
142
+ }
143
+
144
+ interface PackageTranslation {
145
+ translation?: Record<string, string>
146
+ default?: Record<string, string>
147
+ }
148
+
149
+ async function loadPackageTranslations(pluginPath: string, locale: string): Promise<PackageTranslation> {
150
+ const localizedPluginPath = path.join(pluginPath, `package.nls.${locale}.json`);
151
+ try {
152
+ const defaultValue = await fs.readJson(path.join(pluginPath, 'package.nls.json'));
153
+ if (await fs.pathExists(localizedPluginPath)) {
154
+ return {
155
+ translation: await fs.readJson(localizedPluginPath),
156
+ default: defaultValue
157
+ };
158
+ }
159
+ return {
160
+ default: defaultValue
161
+ };
162
+ } catch (e) {
163
+ if (e.code !== 'ENOENT') {
164
+ throw e;
165
+ }
166
+ return {};
167
+ }
168
+ }
169
+
170
+ const NLS_REGEX = /^%([\w\d.-]+)%$/i;
171
+
172
+ function localizePackage(value: unknown, translations: PackageTranslation, callback: (key: string, defaultValue: string) => string): unknown {
173
+ if (typeof value === 'string') {
174
+ const match = NLS_REGEX.exec(value);
175
+ let result = value;
176
+ if (match) {
177
+ const key = match[1];
178
+ if (translations.translation) {
179
+ result = translations.translation[key];
180
+ } else if (translations.default) {
181
+ result = callback(key, translations.default[key]);
182
+ }
183
+ }
184
+ return result;
185
+ }
186
+ if (Array.isArray(value)) {
187
+ const result = [];
188
+ for (const item of value) {
189
+ result.push(localizePackage(item, translations, callback));
190
+ }
191
+ return result;
192
+ }
193
+ if (typeof value === 'object' && value) {
194
+ const result: Record<string, unknown> = {};
195
+ for (const [name, item] of Object.entries(value)) {
196
+ result[name] = localizePackage(item, translations, callback);
197
+ }
198
+ return result;
199
+ }
200
+ return value;
201
+ }
@@ -23,7 +23,7 @@ import { MessageType } from '../../common/rpc-protocol';
23
23
  import { HostedPluginCliContribution } from './hosted-plugin-cli-contribution';
24
24
  import * as psTree from 'ps-tree';
25
25
  import { Deferred } from '@theia/core/lib/common/promise-util';
26
- import { LocalizationProvider } from '@theia/core/lib/node/i18n/localization-provider';
26
+ import { HostedPluginLocalizationService } from './hosted-plugin-localization-service';
27
27
 
28
28
  export interface IPCConnectionOptions {
29
29
  readonly serverName: string;
@@ -56,8 +56,8 @@ export class HostedPluginProcess implements ServerPluginRunner {
56
56
  @inject(MessageService)
57
57
  protected readonly messageService: MessageService;
58
58
 
59
- @inject(LocalizationProvider)
60
- protected readonly localizationProvider: LocalizationProvider;
59
+ @inject(HostedPluginLocalizationService)
60
+ protected readonly localizationService: HostedPluginLocalizationService;
61
61
 
62
62
  private childProcess: cp.ChildProcess | undefined;
63
63
  private client: HostedPluginClient;
@@ -173,9 +173,7 @@ export class HostedPluginProcess implements ServerPluginRunner {
173
173
  delete env[key];
174
174
  }
175
175
  }
176
- const availableLanguages = ['en', ...this.localizationProvider.getAvailableLanguages()];
177
- const locale = this.localizationProvider.getCurrentLanguage();
178
- env['VSCODE_NLS_CONFIG'] = JSON.stringify({ locale, availableLanguages });
176
+ env['VSCODE_NLS_CONFIG'] = JSON.stringify(this.localizationService.getNlsConfig());
179
177
  // apply external env variables
180
178
  this.pluginHostEnvironmentVariables.getContributions().forEach(envVar => envVar.process(env));
181
179
  if (this.cli.extensionTestsPath) {
@@ -33,6 +33,7 @@ import { HostedPluginCliContribution } from './hosted-plugin-cli-contribution';
33
33
  import { HostedPluginDeployerHandler } from './hosted-plugin-deployer-handler';
34
34
  import { PluginUriFactory } from './scanners/plugin-uri-factory';
35
35
  import { FilePluginUriFactory } from './scanners/file-plugin-uri-factory';
36
+ import { HostedPluginLocalizationService } from './hosted-plugin-localization-service';
36
37
 
37
38
  const commonHostedConnectionModule = ConnectionContainerModule.create(({ bind, bindBackendService }) => {
38
39
  bind(HostedPluginProcess).toSelf().inSingletonScope();
@@ -58,6 +59,7 @@ export function bindCommonHostedBackend(bind: interfaces.Bind): void {
58
59
  bind(HostedPluginReader).toSelf().inSingletonScope();
59
60
  bind(BackendApplicationContribution).toService(HostedPluginReader);
60
61
 
62
+ bind(HostedPluginLocalizationService).toSelf().inSingletonScope();
61
63
  bind(HostedPluginDeployerHandler).toSelf().inSingletonScope();
62
64
  bind(PluginDeployerHandler).toService(HostedPluginDeployerHandler);
63
65
 
@@ -14,68 +14,16 @@
14
14
  * SPDX-License-Identifier: EPL-2.0 OR GPL-2.0 WITH Classpath-exception-2.0
15
15
  ********************************************************************************/
16
16
 
17
- /* eslint-disable @typescript-eslint/no-explicit-any */
18
-
19
17
  import * as path from 'path';
20
18
  import * as fs from '@theia/core/shared/fs-extra';
21
19
 
22
- const NLS_REGEX = /^%([\w\d.-]+)%$/i;
23
-
24
- export async function loadManifest(pluginPath: string, locale?: string): Promise<any> {
25
- const [manifest, translations] = await Promise.all([
26
- fs.readJson(path.join(pluginPath, 'package.json')),
27
- loadTranslations(pluginPath, locale)
28
- ]);
20
+ // eslint-disable-next-line @typescript-eslint/no-explicit-any
21
+ export async function loadManifest(pluginPath: string): Promise<any> {
22
+ const manifest = await fs.readJson(path.join(pluginPath, 'package.json'));
29
23
  // translate vscode builtins, as they are published with a prefix. See https://github.com/theia-ide/vscode-builtin-extensions/blob/master/src/republish.js#L50
30
24
  const built_prefix = '@theia/vscode-builtin-';
31
25
  if (manifest && manifest.name && manifest.name.startsWith(built_prefix)) {
32
26
  manifest.name = manifest.name.substr(built_prefix.length);
33
27
  }
34
- return manifest && translations && Object.keys(translations).length ?
35
- localize(manifest, translations) :
36
- manifest;
37
- }
38
-
39
- async function loadTranslations(pluginPath: string, locale?: string): Promise<any> {
40
- try {
41
- const localizedPluginPath = path.join(pluginPath, `package.nls.${locale}.json`);
42
- if (await fs.pathExists(localizedPluginPath)) {
43
- return await fs.readJson(localizedPluginPath);
44
- } else {
45
- return await fs.readJson(path.join(pluginPath, 'package.nls.json'));
46
- }
47
- } catch (e) {
48
- if (e.code !== 'ENOENT') {
49
- throw e;
50
- }
51
- return {};
52
- }
53
- }
54
-
55
- function localize(value: any, translations: {
56
- [key: string]: string
57
- }): any {
58
- if (typeof value === 'string') {
59
- const match = NLS_REGEX.exec(value);
60
- return match && translations[match[1]] || value;
61
- }
62
- if (Array.isArray(value)) {
63
- const result = [];
64
- for (const item of value) {
65
- result.push(localize(item, translations));
66
- }
67
- return result;
68
- }
69
- if (value === null) {
70
- return value;
71
- }
72
- if (typeof value === 'object') {
73
- const result: { [key: string]: any } = {};
74
- // eslint-disable-next-line guard-for-in
75
- for (const propertyName in value) {
76
- result[propertyName] = localize(value[propertyName], translations);
77
- }
78
- return result;
79
- }
80
- return value;
28
+ return manifest;
81
29
  }
@@ -16,13 +16,11 @@
16
16
  import { injectable, inject, named, postConstruct } from '@theia/core/shared/inversify';
17
17
  import { HostedPluginServer, HostedPluginClient, PluginDeployer, GetDeployedPluginsParams, DeployedPlugin } from '../../common/plugin-protocol';
18
18
  import { HostedPluginSupport } from './hosted-plugin';
19
- import { ILogger, Disposable } from '@theia/core';
20
- import { ContributionProvider } from '@theia/core';
19
+ import { ILogger, Disposable, ContributionProvider } from '@theia/core';
21
20
  import { ExtPluginApiProvider, ExtPluginApi } from '../../common/plugin-ext-api-contribution';
22
21
  import { HostedPluginDeployerHandler } from './hosted-plugin-deployer-handler';
23
22
  import { PluginDeployerImpl } from '../../main/node/plugin-deployer-impl';
24
- import { LocalizationProvider } from '@theia/core/lib/node/i18n/localization-provider';
25
- import { loadManifest } from './plugin-manifest-loader';
23
+ import { HostedPluginLocalizationService } from './hosted-plugin-localization-service';
26
24
 
27
25
  @injectable()
28
26
  export class HostedPluginServerImpl implements HostedPluginServer {
@@ -35,8 +33,8 @@ export class HostedPluginServerImpl implements HostedPluginServer {
35
33
  @inject(PluginDeployer)
36
34
  protected readonly pluginDeployer: PluginDeployerImpl;
37
35
 
38
- @inject(LocalizationProvider)
39
- protected readonly localizationProvider: LocalizationProvider;
36
+ @inject(HostedPluginLocalizationService)
37
+ protected readonly localizationService: HostedPluginLocalizationService;
40
38
 
41
39
  @inject(ContributionProvider)
42
40
  @named(Symbol.for(ExtPluginApiProvider))
@@ -90,8 +88,7 @@ export class HostedPluginServerImpl implements HostedPluginServer {
90
88
  if (!pluginIds.length) {
91
89
  return [];
92
90
  }
93
- const locale = this.localizationProvider.getCurrentLanguage();
94
- const plugins = [];
91
+ const plugins: DeployedPlugin[] = [];
95
92
  let extraDeployedPlugins: Map<string, DeployedPlugin> | undefined;
96
93
  for (const pluginId of pluginIds) {
97
94
  let plugin = this.deployerHandler.getDeployedPlugin(pluginId);
@@ -105,10 +102,10 @@ export class HostedPluginServerImpl implements HostedPluginServer {
105
102
  plugin = extraDeployedPlugins.get(pluginId);
106
103
  }
107
104
  if (plugin) {
108
- plugins.push(await this.localizePlugin(plugin, locale));
105
+ plugins.push(plugin);
109
106
  }
110
107
  }
111
- return plugins;
108
+ return Promise.all(plugins.map(plugin => this.localizationService.localizePlugin(plugin)));
112
109
  }
113
110
 
114
111
  onMessage(pluginHostId: string, message: string): Promise<void> {
@@ -119,34 +116,4 @@ export class HostedPluginServerImpl implements HostedPluginServer {
119
116
  getExtPluginAPI(): Promise<ExtPluginApi[]> {
120
117
  return Promise.resolve(this.extPluginAPIContributions.getContributions().map(p => p.provideApi()));
121
118
  }
122
-
123
- protected async localizePlugin(plugin: DeployedPlugin, locale: string): Promise<DeployedPlugin> {
124
- const packagePath = plugin.metadata.model.packagePath;
125
- const translatedManifest = await loadManifest(packagePath, locale);
126
- this.mergeContributes(plugin.contributes, translatedManifest.contributes);
127
- return plugin;
128
- }
129
-
130
- // eslint-disable-next-line @typescript-eslint/no-explicit-any
131
- protected mergeContributes(main: any, other: any): void {
132
- if (main && other) {
133
- if (Array.isArray(main) && Array.isArray(other)) {
134
- for (let i = 0; i < main.length && i < other.length; i++) {
135
- if (typeof main[i] === 'object' && typeof other[i] === 'object') {
136
- this.mergeContributes(main[i], other[i]);
137
- }
138
- }
139
- } else {
140
- for (const [key, value] of Object.entries(main)) {
141
- if (key in other) {
142
- if (typeof value === 'string') {
143
- main[key] = other[key];
144
- } else if (typeof value === 'object' && typeof other[key] === 'object') {
145
- this.mergeContributes(main[key], other[key]);
146
- }
147
- }
148
- }
149
- }
150
- }
151
- }
152
119
  }