forked from continuedev/continue
-
Notifications
You must be signed in to change notification settings - Fork 1
/
activate.ts
52 lines (44 loc) · 1.66 KB
/
activate.ts
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
import { getTsConfigPath, migrate } from "core/util/paths";
import { Telemetry } from "core/util/posthog";
import path from "node:path";
import * as vscode from "vscode";
import { VsCodeExtension } from "../extension/vscodeExtension";
import registerQuickFixProvider from "../lang-server/codeActions";
import { getExtensionVersion } from "../util/util";
import { getExtensionUri } from "../util/vscode";
import { VsCodeContinueApi } from "./api";
import { setupInlineTips } from "./inlineTips";
let resolveVsCodeExtension = (_: VsCodeExtension): void => {};
export const vscodeExtensionPromise: Promise<VsCodeExtension> = new Promise(
(resolve) => (resolveVsCodeExtension = resolve),
);
export async function activateExtension(context: vscode.ExtensionContext) {
// Add necessary files
getTsConfigPath();
// Register commands and providers
registerQuickFixProvider();
setupInlineTips(context);
const vscodeExtension = new VsCodeExtension(context);
resolveVsCodeExtension(vscodeExtension);
migrate("showWelcome_1", () => {
vscode.commands.executeCommand(
"markdown.showPreview",
vscode.Uri.file(
path.join(getExtensionUri().fsPath, "media", "welcome.md"),
),
);
});
// Load Continue configuration
if (!context.globalState.get("hasBeenInstalled")) {
context.globalState.update("hasBeenInstalled", true);
Telemetry.capture("install", {
extensionVersion: getExtensionVersion(),
});
}
const api = new VsCodeContinueApi(vscodeExtension);
const continuePublicApi = {
registerCustomContextProvider: api.registerCustomContextProvider.bind(api),
};
// 'export' public api-surface
return continuePublicApi;
}