Book a Demo!
CoCalc Logo Icon
StoreFeaturesDocsShareSupportNewsAboutPoliciesSign UpSign In
microsoft
GitHub Repository: microsoft/vscode
Path: blob/main/extensions/html-language-features/client/src/browser/htmlClientMain.ts
3323 views
1
/*---------------------------------------------------------------------------------------------
2
* Copyright (c) Microsoft Corporation. All rights reserved.
3
* Licensed under the MIT License. See License.txt in the project root for license information.
4
*--------------------------------------------------------------------------------------------*/
5
6
import { Disposable, ExtensionContext, Uri, l10n } from 'vscode';
7
import { LanguageClientOptions } from 'vscode-languageclient';
8
import { startClient, LanguageClientConstructor, AsyncDisposable } from '../htmlClient';
9
import { LanguageClient } from 'vscode-languageclient/browser';
10
11
let client: AsyncDisposable | undefined;
12
13
// this method is called when vs code is activated
14
export async function activate(context: ExtensionContext) {
15
const serverMain = Uri.joinPath(context.extensionUri, 'server/dist/browser/htmlServerMain.js');
16
try {
17
const worker = new Worker(serverMain.toString());
18
worker.postMessage({ i10lLocation: l10n.uri?.toString(false) ?? '' });
19
20
const newLanguageClient: LanguageClientConstructor = (id: string, name: string, clientOptions: LanguageClientOptions) => {
21
return new LanguageClient(id, name, worker, clientOptions);
22
};
23
24
const timer = {
25
setTimeout(callback: (...args: any[]) => void, ms: number, ...args: any[]): Disposable {
26
const handle = setTimeout(callback, ms, ...args);
27
return { dispose: () => clearTimeout(handle) };
28
}
29
};
30
31
client = await startClient(context, newLanguageClient, { TextDecoder, timer });
32
33
} catch (e) {
34
console.log(e);
35
}
36
}
37
38
export async function deactivate(): Promise<void> {
39
if (client) {
40
await client.dispose();
41
client = undefined;
42
}
43
}
44
45
46