@theia/plugin-ext 1.18.0 → 1.21.0-next.12
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.
- package/README.md +5 -0
- package/lib/common/connection.d.ts +47 -34
- package/lib/common/connection.d.ts.map +1 -1
- package/lib/common/connection.js +90 -28
- package/lib/common/connection.js.map +1 -1
- package/lib/common/plugin-api-rpc-model.d.ts +2 -0
- package/lib/common/plugin-api-rpc-model.d.ts.map +1 -1
- package/lib/common/plugin-api-rpc-model.js.map +1 -1
- package/lib/common/plugin-api-rpc.d.ts +10 -11
- package/lib/common/plugin-api-rpc.d.ts.map +1 -1
- package/lib/common/plugin-api-rpc.js.map +1 -1
- package/lib/common/plugin-protocol.d.ts +3 -1
- package/lib/common/plugin-protocol.d.ts.map +1 -1
- package/lib/common/plugin-protocol.js.map +1 -1
- package/lib/hosted/browser/hosted-plugin.d.ts +4 -5
- package/lib/hosted/browser/hosted-plugin.d.ts.map +1 -1
- package/lib/hosted/browser/hosted-plugin.js +18 -14
- package/lib/hosted/browser/hosted-plugin.js.map +1 -1
- package/lib/hosted/node/hosted-plugin-deployer-handler.d.ts +1 -1
- package/lib/hosted/node/hosted-plugin-deployer-handler.d.ts.map +1 -1
- package/lib/hosted/node/hosted-plugin-deployer-handler.js +14 -38
- package/lib/hosted/node/hosted-plugin-deployer-handler.js.map +1 -1
- package/lib/hosted/node/hosted-plugin-localization-service.d.ts +37 -0
- package/lib/hosted/node/hosted-plugin-localization-service.d.ts.map +1 -0
- package/lib/hosted/node/hosted-plugin-localization-service.js +197 -0
- package/lib/hosted/node/hosted-plugin-localization-service.js.map +1 -0
- package/lib/hosted/node/hosted-plugin-process.d.ts +2 -2
- package/lib/hosted/node/hosted-plugin-process.d.ts.map +1 -1
- package/lib/hosted/node/hosted-plugin-process.js +5 -7
- package/lib/hosted/node/hosted-plugin-process.js.map +1 -1
- package/lib/hosted/node/plugin-ext-hosted-backend-module.d.ts.map +1 -1
- package/lib/hosted/node/plugin-ext-hosted-backend-module.js +2 -0
- package/lib/hosted/node/plugin-ext-hosted-backend-module.js.map +1 -1
- package/lib/hosted/node/plugin-manifest-loader.d.ts +1 -1
- package/lib/hosted/node/plugin-manifest-loader.d.ts.map +1 -1
- package/lib/hosted/node/plugin-manifest-loader.js +4 -52
- package/lib/hosted/node/plugin-manifest-loader.js.map +1 -1
- package/lib/hosted/node/plugin-service.d.ts +3 -6
- package/lib/hosted/node/plugin-service.d.ts.map +1 -1
- package/lib/hosted/node/plugin-service.js +7 -40
- package/lib/hosted/node/plugin-service.js.map +1 -1
- package/lib/hosted/node/scanners/scanner-theia.d.ts +1 -1
- package/lib/hosted/node/scanners/scanner-theia.d.ts.map +1 -1
- package/lib/hosted/node/scanners/scanner-theia.js +5 -1
- package/lib/hosted/node/scanners/scanner-theia.js.map +1 -1
- package/lib/main/browser/callhierarchy/callhierarchy-type-converters.d.ts.map +1 -1
- package/lib/main/browser/callhierarchy/callhierarchy-type-converters.js +5 -2
- package/lib/main/browser/callhierarchy/callhierarchy-type-converters.js.map +1 -1
- package/lib/main/browser/custom-editors/custom-editor-opener.d.ts +1 -2
- package/lib/main/browser/custom-editors/custom-editor-opener.d.ts.map +1 -1
- package/lib/main/browser/custom-editors/custom-editor-opener.js.map +1 -1
- package/lib/main/browser/custom-editors/custom-editors-main.d.ts.map +1 -1
- package/lib/main/browser/custom-editors/custom-editors-main.js +1 -2
- package/lib/main/browser/custom-editors/custom-editors-main.js.map +1 -1
- package/lib/main/browser/debug/debug-main.d.ts +3 -3
- package/lib/main/browser/debug/debug-main.d.ts.map +1 -1
- package/lib/main/browser/debug/debug-main.js +2 -3
- package/lib/main/browser/debug/debug-main.js.map +1 -1
- package/lib/main/browser/debug/plugin-debug-session-factory.d.ts +6 -6
- package/lib/main/browser/debug/plugin-debug-session-factory.d.ts.map +1 -1
- package/lib/main/browser/debug/plugin-debug-session-factory.js +1 -1
- package/lib/main/browser/debug/plugin-debug-session-factory.js.map +1 -1
- package/lib/main/browser/dialogs/modal-notification.d.ts +3 -3
- package/lib/main/browser/dialogs/modal-notification.d.ts.map +1 -1
- package/lib/main/browser/dialogs/modal-notification.js +17 -6
- package/lib/main/browser/dialogs/modal-notification.js.map +1 -1
- package/lib/main/browser/editors-and-documents-main.d.ts.map +1 -1
- package/lib/main/browser/editors-and-documents-main.js +3 -4
- package/lib/main/browser/editors-and-documents-main.js.map +1 -1
- package/lib/main/browser/file-system-main-impl.js +1 -1
- package/lib/main/browser/file-system-main-impl.js.map +1 -1
- package/lib/main/browser/languages-main.js +1 -1
- package/lib/main/browser/languages-main.js.map +1 -1
- package/lib/main/browser/main-context.js +2 -2
- package/lib/main/browser/main-context.js.map +1 -1
- package/lib/main/browser/message-registry-main.js +1 -1
- package/lib/main/browser/message-registry-main.js.map +1 -1
- package/lib/main/browser/quick-open-main.d.ts +1 -1
- package/lib/main/browser/quick-open-main.d.ts.map +1 -1
- package/lib/main/browser/quick-open-main.js.map +1 -1
- package/lib/main/browser/tasks-main.d.ts.map +1 -1
- package/lib/main/browser/tasks-main.js +6 -0
- package/lib/main/browser/tasks-main.js.map +1 -1
- package/lib/main/browser/timeline-main.d.ts.map +1 -1
- package/lib/main/browser/timeline-main.js +1 -1
- package/lib/main/browser/timeline-main.js.map +1 -1
- package/lib/main/browser/view/plugin-view-registry.d.ts +3 -2
- package/lib/main/browser/view/plugin-view-registry.d.ts.map +1 -1
- package/lib/main/browser/view/plugin-view-registry.js +77 -26
- package/lib/main/browser/view/plugin-view-registry.js.map +1 -1
- package/lib/main/browser/view/plugin-view-widget.d.ts +2 -0
- package/lib/main/browser/view/plugin-view-widget.d.ts.map +1 -1
- package/lib/main/browser/view/plugin-view-widget.js +3 -1
- package/lib/main/browser/view/plugin-view-widget.js.map +1 -1
- package/lib/main/browser/view/tree-view-widget.d.ts +3 -7
- package/lib/main/browser/view/tree-view-widget.d.ts.map +1 -1
- package/lib/main/browser/view/tree-view-widget.js +26 -39
- package/lib/main/browser/view/tree-view-widget.js.map +1 -1
- package/lib/main/browser/webview/webview-frontend-security-warnings.d.ts.map +1 -1
- package/lib/main/browser/webview/webview-frontend-security-warnings.js +8 -5
- package/lib/main/browser/webview/webview-frontend-security-warnings.js.map +1 -1
- package/lib/main/browser/webview/webview-preferences.d.ts.map +1 -1
- package/lib/main/browser/webview/webview-preferences.js +3 -2
- package/lib/main/browser/webview/webview-preferences.js.map +1 -1
- package/lib/main/browser/webview/webview.d.ts +1 -1
- package/lib/main/browser/webview/webview.d.ts.map +1 -1
- package/lib/main/browser/webview/webview.js +1 -1
- package/lib/main/browser/webview/webview.js.map +1 -1
- package/lib/plugin/comments.d.ts.map +1 -1
- package/lib/plugin/comments.js +2 -3
- package/lib/plugin/comments.js.map +1 -1
- package/lib/plugin/custom-editors.d.ts +1 -2
- package/lib/plugin/custom-editors.d.ts.map +1 -1
- package/lib/plugin/custom-editors.js +2 -3
- package/lib/plugin/custom-editors.js.map +1 -1
- package/lib/plugin/decorations.d.ts.map +1 -1
- package/lib/plugin/decorations.js +2 -3
- package/lib/plugin/decorations.js.map +1 -1
- package/lib/plugin/document-data.d.ts.map +1 -1
- package/lib/plugin/document-data.js +1 -1
- package/lib/plugin/document-data.js.map +1 -1
- package/lib/plugin/documents.d.ts.map +1 -1
- package/lib/plugin/documents.js +1 -2
- package/lib/plugin/documents.js.map +1 -1
- package/lib/plugin/file-system-event-service-ext-impl.d.ts.map +1 -1
- package/lib/plugin/file-system-event-service-ext-impl.js +2 -3
- package/lib/plugin/file-system-event-service-ext-impl.js.map +1 -1
- package/lib/plugin/file-system-ext-impl.d.ts.map +1 -1
- package/lib/plugin/file-system-ext-impl.js +12 -13
- package/lib/plugin/file-system-ext-impl.js.map +1 -1
- package/lib/plugin/known-commands.spec.js +1 -2
- package/lib/plugin/known-commands.spec.js.map +1 -1
- package/lib/plugin/languages/call-hierarchy.d.ts +1 -1
- package/lib/plugin/languages/call-hierarchy.d.ts.map +1 -1
- package/lib/plugin/languages/call-hierarchy.js +7 -3
- package/lib/plugin/languages/call-hierarchy.js.map +1 -1
- package/lib/plugin/languages/rename.d.ts +1 -2
- package/lib/plugin/languages/rename.d.ts.map +1 -1
- package/lib/plugin/languages/rename.js.map +1 -1
- package/lib/plugin/languages.d.ts +1 -1
- package/lib/plugin/languages.d.ts.map +1 -1
- package/lib/plugin/languages.js.map +1 -1
- package/lib/plugin/message-registry.d.ts.map +1 -1
- package/lib/plugin/message-registry.js +3 -0
- package/lib/plugin/message-registry.js.map +1 -1
- package/lib/plugin/node/debug/debug.d.ts +4 -4
- package/lib/plugin/node/debug/debug.d.ts.map +1 -1
- package/lib/plugin/node/debug/debug.js +13 -8
- package/lib/plugin/node/debug/debug.js.map +1 -1
- package/lib/plugin/node/debug/plugin-debug-adapter-session.d.ts +7 -7
- package/lib/plugin/node/debug/plugin-debug-adapter-session.d.ts.map +1 -1
- package/lib/plugin/node/debug/plugin-debug-adapter-session.js +6 -6
- package/lib/plugin/node/debug/plugin-debug-adapter-session.js.map +1 -1
- package/lib/plugin/node/debug/plugin-debug-adapter-starter.d.ts +8 -4
- package/lib/plugin/node/debug/plugin-debug-adapter-starter.d.ts.map +1 -1
- package/lib/plugin/node/debug/plugin-debug-adapter-starter.js +16 -13
- package/lib/plugin/node/debug/plugin-debug-adapter-starter.js.map +1 -1
- package/lib/plugin/plugin-context.d.ts.map +1 -1
- package/lib/plugin/plugin-context.js +5 -4
- package/lib/plugin/plugin-context.js.map +1 -1
- package/lib/plugin/plugin-storage.d.ts.map +1 -1
- package/lib/plugin/plugin-storage.js.map +1 -1
- package/lib/plugin/preference-registry.spec.js.map +1 -1
- package/lib/plugin/quick-open.d.ts +1 -1
- package/lib/plugin/quick-open.d.ts.map +1 -1
- package/lib/plugin/quick-open.js +11 -6
- package/lib/plugin/quick-open.js.map +1 -1
- package/lib/plugin/tasks/tasks.d.ts +1 -3
- package/lib/plugin/tasks/tasks.d.ts.map +1 -1
- package/lib/plugin/tasks/tasks.js +3 -17
- package/lib/plugin/tasks/tasks.js.map +1 -1
- package/lib/plugin/timeline.d.ts.map +1 -1
- package/lib/plugin/timeline.js +1 -2
- package/lib/plugin/timeline.js.map +1 -1
- package/lib/plugin/type-converters.d.ts.map +1 -1
- package/lib/plugin/type-converters.js +10 -7
- package/lib/plugin/type-converters.js.map +1 -1
- package/lib/plugin/types-impl.d.ts +34 -0
- package/lib/plugin/types-impl.d.ts.map +1 -1
- package/lib/plugin/types-impl.js +61 -1
- package/lib/plugin/types-impl.js.map +1 -1
- package/lib/plugin/webviews.d.ts +1 -2
- package/lib/plugin/webviews.d.ts.map +1 -1
- package/lib/plugin/webviews.js.map +1 -1
- package/package.json +26 -24
- package/src/common/connection.ts +98 -42
- package/src/common/plugin-api-rpc-model.ts +2 -0
- package/src/common/plugin-api-rpc.ts +10 -11
- package/src/common/plugin-protocol.ts +3 -2
- package/src/hosted/browser/hosted-plugin.ts +17 -12
- package/src/hosted/node/hosted-plugin-deployer-handler.ts +13 -40
- package/src/hosted/node/hosted-plugin-localization-service.ts +201 -0
- package/src/hosted/node/hosted-plugin-process.ts +4 -6
- package/src/hosted/node/plugin-ext-hosted-backend-module.ts +2 -0
- package/src/hosted/node/plugin-manifest-loader.ts +4 -56
- package/src/hosted/node/plugin-service.ts +7 -40
- package/src/hosted/node/scanners/scanner-theia.ts +6 -3
- package/src/main/browser/callhierarchy/callhierarchy-type-converters.ts +5 -2
- package/src/main/browser/custom-editors/custom-editor-opener.tsx +1 -2
- package/src/main/browser/custom-editors/custom-editors-main.ts +1 -2
- package/src/main/browser/debug/debug-main.ts +4 -5
- package/src/main/browser/debug/plugin-debug-session-factory.ts +6 -6
- package/src/main/browser/dialogs/modal-notification.ts +18 -7
- package/src/main/browser/dialogs/style/modal-notification.css +17 -2
- package/src/main/browser/editors-and-documents-main.ts +1 -2
- package/src/main/browser/file-system-main-impl.ts +1 -1
- package/src/main/browser/languages-main.ts +1 -1
- package/src/main/browser/main-context.ts +3 -3
- package/src/main/browser/message-registry-main.ts +1 -1
- package/src/main/browser/quick-open-main.ts +1 -1
- package/src/main/browser/style/tree.css +4 -0
- package/src/main/browser/tasks-main.ts +7 -0
- package/src/main/browser/timeline-main.ts +1 -2
- package/src/main/browser/view/plugin-view-registry.ts +83 -28
- package/src/main/browser/view/plugin-view-widget.ts +7 -2
- package/src/main/browser/view/tree-view-widget.tsx +43 -65
- package/src/main/browser/webview/pre/host.js +3 -4
- package/src/main/browser/webview/webview-frontend-security-warnings.ts +8 -7
- package/src/main/browser/webview/webview-preferences.ts +3 -2
- package/src/main/browser/webview/webview.ts +1 -1
- package/src/plugin/comments.ts +1 -2
- package/src/plugin/custom-editors.ts +2 -4
- package/src/plugin/decorations.ts +1 -2
- package/src/plugin/document-data.ts +1 -2
- package/src/plugin/documents.ts +1 -2
- package/src/plugin/file-system-event-service-ext-impl.ts +1 -2
- package/src/plugin/file-system-ext-impl.ts +1 -2
- package/src/plugin/known-commands.spec.ts +1 -2
- package/src/plugin/languages/call-hierarchy.ts +13 -5
- package/src/plugin/languages/rename.ts +1 -2
- package/src/plugin/languages.ts +3 -1
- package/src/plugin/message-registry.ts +3 -1
- package/src/plugin/node/debug/debug.ts +20 -14
- package/src/plugin/node/debug/plugin-debug-adapter-session.ts +9 -9
- package/src/plugin/node/debug/plugin-debug-adapter-starter.ts +17 -14
- package/src/plugin/plugin-context.ts +10 -7
- package/src/plugin/plugin-storage.ts +1 -2
- package/src/plugin/preference-registry.spec.ts +1 -2
- package/src/plugin/quick-open.ts +14 -10
- package/src/plugin/tasks/tasks.ts +4 -18
- package/src/plugin/timeline.ts +1 -2
- package/src/plugin/type-converters.ts +12 -8
- package/src/plugin/types-impl.ts +53 -0
- package/src/plugin/webviews.ts +1 -2
- package/lib/common/plugin-message-reader.d.ts +0 -46
- package/lib/common/plugin-message-reader.d.ts.map +0 -1
- package/lib/common/plugin-message-reader.js +0 -116
- package/lib/common/plugin-message-reader.js.map +0 -1
- package/lib/common/plugin-message-writer.d.ts +0 -38
- package/lib/common/plugin-message-writer.d.ts.map +0 -1
- package/lib/common/plugin-message-writer.js +0 -67
- package/lib/common/plugin-message-writer.js.map +0 -1
- package/lib/main/browser/connection-main.d.ts +0 -59
- package/lib/main/browser/connection-main.d.ts.map +0 -1
- package/lib/main/browser/connection-main.js +0 -98
- package/lib/main/browser/connection-main.js.map +0 -1
- package/lib/plugin/connection-ext.d.ts +0 -56
- package/lib/plugin/connection-ext.d.ts.map +0 -1
- package/lib/plugin/connection-ext.js +0 -88
- package/lib/plugin/connection-ext.js.map +0 -1
- package/src/common/plugin-message-reader.ts +0 -111
- package/src/common/plugin-message-writer.ts +0 -65
- package/src/main/browser/connection-main.ts +0 -107
- package/src/plugin/connection-ext.ts +0 -95
|
@@ -22,6 +22,7 @@ import { PluginLifecycle, PluginModel, PluginMetadata, PluginPackage, IconUrl, P
|
|
|
22
22
|
import { QueryParameters } from './env';
|
|
23
23
|
import { TextEditorCursorStyle } from './editor-options';
|
|
24
24
|
import {
|
|
25
|
+
ConfigurationTarget,
|
|
25
26
|
TextEditorLineNumbersStyle,
|
|
26
27
|
EndOfLine,
|
|
27
28
|
OverviewRulerLane,
|
|
@@ -29,7 +30,6 @@ import {
|
|
|
29
30
|
FileOperationOptions
|
|
30
31
|
} from '../plugin/types-impl';
|
|
31
32
|
import { UriComponents } from './uri-components';
|
|
32
|
-
import { ConfigurationTarget } from '../plugin/types-impl';
|
|
33
33
|
import {
|
|
34
34
|
SerializedDocumentFilter,
|
|
35
35
|
CompletionContext,
|
|
@@ -91,8 +91,7 @@ import type {
|
|
|
91
91
|
TimelineProviderDescriptor
|
|
92
92
|
} from '@theia/timeline/lib/common/timeline-model';
|
|
93
93
|
import { SerializableEnvironmentVariableCollection } from '@theia/terminal/lib/common/base-terminal-protocol';
|
|
94
|
-
|
|
95
|
-
import { ThemeType } from '@theia/core/lib/browser/theming';
|
|
94
|
+
import { ThemeType } from '@theia/core/lib/common/theme';
|
|
96
95
|
import { Disposable } from '@theia/core/lib/common/disposable';
|
|
97
96
|
import { PickOptions, QuickInputButtonHandle, QuickPickItem } from '@theia/core/lib/browser';
|
|
98
97
|
|
|
@@ -266,8 +265,6 @@ export interface ConnectionMain {
|
|
|
266
265
|
$createConnection(id: string): Promise<void>;
|
|
267
266
|
$deleteConnection(id: string): Promise<void>;
|
|
268
267
|
$sendMessage(id: string, message: string): void;
|
|
269
|
-
$createConnection(id: string): Promise<void>;
|
|
270
|
-
$deleteConnection(id: string): Promise<void>;
|
|
271
268
|
}
|
|
272
269
|
|
|
273
270
|
export interface ConnectionExt {
|
|
@@ -383,6 +380,7 @@ export enum MainMessageType {
|
|
|
383
380
|
}
|
|
384
381
|
|
|
385
382
|
export interface MainMessageOptions {
|
|
383
|
+
detail?: string;
|
|
386
384
|
modal?: boolean
|
|
387
385
|
onCloseActionHandle?: number
|
|
388
386
|
}
|
|
@@ -555,7 +553,7 @@ export interface TransferQuickInputButton extends theia.QuickInputButton {
|
|
|
555
553
|
handle?: number;
|
|
556
554
|
}
|
|
557
555
|
|
|
558
|
-
export type TransferQuickInput
|
|
556
|
+
export type TransferQuickInput = TransferQuickPick | TransferInputBox;
|
|
559
557
|
|
|
560
558
|
export interface BaseTransferQuickInput {
|
|
561
559
|
[key: string]: any;
|
|
@@ -566,14 +564,14 @@ export interface BaseTransferQuickInput {
|
|
|
566
564
|
visible?: boolean;
|
|
567
565
|
}
|
|
568
566
|
|
|
569
|
-
export interface TransferQuickPick
|
|
567
|
+
export interface TransferQuickPick extends BaseTransferQuickInput {
|
|
570
568
|
type?: 'quickPick';
|
|
571
569
|
value?: string;
|
|
572
570
|
placeholder?: string;
|
|
573
571
|
buttons?: TransferQuickInputButton[];
|
|
574
572
|
items?: TransferQuickPickItems[];
|
|
575
|
-
activeItems?: ReadonlyArray<
|
|
576
|
-
selectedItems?: ReadonlyArray<
|
|
573
|
+
activeItems?: ReadonlyArray<theia.QuickPickItem>;
|
|
574
|
+
selectedItems?: ReadonlyArray<theia.QuickPickItem>;
|
|
577
575
|
canSelectMany?: boolean;
|
|
578
576
|
ignoreFocusOut?: boolean;
|
|
579
577
|
matchOnDescription?: boolean;
|
|
@@ -605,7 +603,7 @@ export interface QuickOpenMain {
|
|
|
605
603
|
$setItems(instance: number, items: TransferQuickPickItems[]): Promise<any>;
|
|
606
604
|
$setError(instance: number, error: Error): Promise<void>;
|
|
607
605
|
$input(options: theia.InputBoxOptions, validateInput: boolean, token: CancellationToken): Promise<string | undefined>;
|
|
608
|
-
$createOrUpdate<T extends theia.QuickPickItem>(params: TransferQuickInput
|
|
606
|
+
$createOrUpdate<T extends theia.QuickPickItem>(params: TransferQuickInput): Promise<void>;
|
|
609
607
|
$dispose(id: number): Promise<void>;
|
|
610
608
|
|
|
611
609
|
$hide(): void;
|
|
@@ -1458,7 +1456,7 @@ export interface LanguagesExt {
|
|
|
1458
1456
|
$provideDocumentSemanticTokens(handle: number, resource: UriComponents, previousResultId: number, token: CancellationToken): Promise<BinaryBuffer | null>;
|
|
1459
1457
|
$releaseDocumentSemanticTokens(handle: number, semanticColoringResultId: number): void;
|
|
1460
1458
|
$provideDocumentRangeSemanticTokens(handle: number, resource: UriComponents, range: Range, token: CancellationToken): Promise<BinaryBuffer | null>;
|
|
1461
|
-
$provideRootDefinition(handle: number, resource: UriComponents, location: Position, token: CancellationToken): Promise<CallHierarchyDefinition | undefined>;
|
|
1459
|
+
$provideRootDefinition(handle: number, resource: UriComponents, location: Position, token: CancellationToken): Promise<CallHierarchyDefinition | CallHierarchyDefinition[] | undefined>;
|
|
1462
1460
|
$provideCallers(handle: number, definition: CallHierarchyDefinition, token: CancellationToken): Promise<CallHierarchyReference[] | undefined>;
|
|
1463
1461
|
$provideCallees(handle: number, definition: CallHierarchyDefinition, token: CancellationToken): Promise<CallHierarchyReference[] | undefined>;
|
|
1464
1462
|
}
|
|
@@ -1793,6 +1791,7 @@ export const MAIN_RPC_CONTEXT = {
|
|
|
1793
1791
|
};
|
|
1794
1792
|
|
|
1795
1793
|
export interface TasksExt {
|
|
1794
|
+
$initLoadedTasks(executions: TaskExecutionDto[]): Promise<void>;
|
|
1796
1795
|
$provideTasks(handle: number): Promise<TaskDto[] | undefined>;
|
|
1797
1796
|
$resolveTask(handle: number, task: TaskDto, token?: CancellationToken): Promise<TaskDto | undefined>;
|
|
1798
1797
|
$onDidStartTask(execution: TaskExecutionDto, terminalId: number): void;
|
|
@@ -23,8 +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
|
-
|
|
27
|
-
import { ColorDefinition } from '@theia/core/lib/browser/color-registry';
|
|
26
|
+
import { ColorDefinition } from '@theia/core/lib/common/color';
|
|
28
27
|
import { ResourceLabelFormatter } from '@theia/core/lib/common/label-protocol';
|
|
29
28
|
|
|
30
29
|
export const hostedServicePath = '/services/hostedPlugin';
|
|
@@ -555,6 +554,7 @@ export interface Localization {
|
|
|
555
554
|
|
|
556
555
|
export interface Translation {
|
|
557
556
|
id: string;
|
|
557
|
+
path: string;
|
|
558
558
|
version: string;
|
|
559
559
|
contents: { [scope: string]: { [key: string]: string } }
|
|
560
560
|
}
|
|
@@ -681,6 +681,7 @@ export interface ViewContainer {
|
|
|
681
681
|
id: string;
|
|
682
682
|
title: string;
|
|
683
683
|
iconUrl: string;
|
|
684
|
+
themeIcon?: string;
|
|
684
685
|
}
|
|
685
686
|
|
|
686
687
|
/**
|
|
@@ -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';
|
|
@@ -304,12 +302,15 @@ export class HostedPluginSupport {
|
|
|
304
302
|
*/
|
|
305
303
|
protected async syncPlugins(): Promise<void> {
|
|
306
304
|
let initialized = 0;
|
|
307
|
-
const
|
|
305
|
+
const waitPluginsMeasurement = this.createMeasurement('waitForDeployment');
|
|
306
|
+
let syncPluginsMeasurement: () => number;
|
|
308
307
|
|
|
309
308
|
const toUnload = new Set(this.contributions.keys());
|
|
310
309
|
try {
|
|
311
310
|
const pluginIds: string[] = [];
|
|
312
311
|
const deployedPluginIds = await this.server.getDeployedPluginIds();
|
|
312
|
+
this.logMeasurement('Waiting for backend deployment', waitPluginsMeasurement);
|
|
313
|
+
syncPluginsMeasurement = this.createMeasurement('syncPlugins');
|
|
313
314
|
for (const pluginId of deployedPluginIds) {
|
|
314
315
|
toUnload.delete(pluginId);
|
|
315
316
|
if (!this.contributions.has(pluginId)) {
|
|
@@ -338,7 +339,7 @@ export class HostedPluginSupport {
|
|
|
338
339
|
}
|
|
339
340
|
}
|
|
340
341
|
|
|
341
|
-
this.logMeasurement(
|
|
342
|
+
this.logMeasurement(`Sync of ${this.getPluginCount(initialized)}`, syncPluginsMeasurement);
|
|
342
343
|
}
|
|
343
344
|
|
|
344
345
|
/**
|
|
@@ -376,7 +377,7 @@ export class HostedPluginSupport {
|
|
|
376
377
|
}
|
|
377
378
|
}
|
|
378
379
|
|
|
379
|
-
this.logMeasurement(
|
|
380
|
+
this.logMeasurement(`Load contributions of ${this.getPluginCount(loaded)}`, loadPluginsMeasurement);
|
|
380
381
|
|
|
381
382
|
return hostContributions;
|
|
382
383
|
}
|
|
@@ -446,7 +447,7 @@ export class HostedPluginSupport {
|
|
|
446
447
|
return;
|
|
447
448
|
}
|
|
448
449
|
|
|
449
|
-
this.logMeasurement(
|
|
450
|
+
this.logMeasurement(`Start of ${this.getPluginCount(started)}`, startPluginsMeasurement);
|
|
450
451
|
}
|
|
451
452
|
|
|
452
453
|
protected async obtainManager(host: string, hostContributions: PluginContributions[], toDisconnect: DisposableCollection): Promise<PluginManagerExt | undefined> {
|
|
@@ -541,7 +542,7 @@ export class HostedPluginSupport {
|
|
|
541
542
|
|
|
542
543
|
// Make sure that folder by the path exists
|
|
543
544
|
if (!await this.fileService.exists(globalStorageFolderUri)) {
|
|
544
|
-
await this.fileService.createFolder(globalStorageFolderUri);
|
|
545
|
+
await this.fileService.createFolder(globalStorageFolderUri, { fromUserGesture: false });
|
|
545
546
|
}
|
|
546
547
|
const globalStorageFolderFsPath = await this.fileService.fsPath(globalStorageFolderUri);
|
|
547
548
|
if (!globalStorageFolderFsPath) {
|
|
@@ -714,15 +715,19 @@ export class HostedPluginSupport {
|
|
|
714
715
|
};
|
|
715
716
|
}
|
|
716
717
|
|
|
717
|
-
protected logMeasurement(
|
|
718
|
+
protected logMeasurement(measurementName: string, measurement: () => number): void {
|
|
718
719
|
const duration = measurement();
|
|
719
720
|
if (duration === Number.NaN) {
|
|
720
721
|
// Measurement was prevented by native API, do not log NaN duration
|
|
721
722
|
return;
|
|
722
723
|
}
|
|
723
724
|
|
|
724
|
-
const
|
|
725
|
-
console.log(`[${this.clientId}] ${
|
|
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'}`;
|
|
726
731
|
}
|
|
727
732
|
|
|
728
733
|
protected readonly webviewsToRestore = new Set<WebviewWidget>();
|
|
@@ -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,
|
|
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 {
|
|
24
|
-
import {
|
|
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(
|
|
36
|
-
private readonly
|
|
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
|
-
|
|
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
|
-
|
|
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 {
|
|
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(
|
|
60
|
-
protected readonly
|
|
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
|
-
|
|
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
|
-
|
|
23
|
-
|
|
24
|
-
|
|
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
|
|
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
|
}
|