2019-01-19 04:46:40 +07:00
|
|
|
import "./fill/require";
|
2019-01-23 01:27:59 +07:00
|
|
|
import * as paths from "./fill/paths";
|
2019-01-19 04:46:40 +07:00
|
|
|
import "./fill/storageDatabase";
|
|
|
|
import "./fill/windowsService";
|
2019-01-23 01:27:59 +07:00
|
|
|
import "./fill/environmentService";
|
2019-01-29 00:14:06 +07:00
|
|
|
import "./fill/vscodeTextmate";
|
2019-01-19 07:04:24 +07:00
|
|
|
import "./fill/dom";
|
|
|
|
import "./vscode.scss";
|
2019-01-19 04:46:40 +07:00
|
|
|
|
|
|
|
import { Client as IDEClient, IURI, IURIFactory } from "@coder/ide";
|
|
|
|
|
|
|
|
import { registerContextMenuListener } from "vs/base/parts/contextmenu/electron-main/contextmenu";
|
|
|
|
import { LogLevel } from "vs/platform/log/common/log";
|
|
|
|
import { toLocalISOString } from "vs/base/common/date";
|
|
|
|
// import { RawContextKey, IContextKeyService } from "vs/platform/contextkey/common/contextkey";
|
|
|
|
import { URI } from "vs/base/common/uri";
|
|
|
|
|
2019-01-19 07:04:24 +07:00
|
|
|
import { Protocol } from "vs/base/parts/ipc/node/ipc.net";
|
2019-01-19 04:46:40 +07:00
|
|
|
|
|
|
|
export class Client extends IDEClient {
|
|
|
|
|
|
|
|
private readonly windowId = parseInt(toLocalISOString(new Date()).replace(/[-:.TZ]/g, ""), 10);
|
2019-01-19 07:04:24 +07:00
|
|
|
|
2019-01-19 04:46:40 +07:00
|
|
|
public readonly protocolPromise: Promise<Protocol>;
|
2019-01-19 07:04:24 +07:00
|
|
|
public protoResolve: ((protocol: Protocol) => void) | undefined;
|
2019-01-29 00:14:06 +07:00
|
|
|
private readonly pathSets: Promise<void>;
|
2019-01-19 04:46:40 +07:00
|
|
|
|
|
|
|
public constructor() {
|
|
|
|
super();
|
|
|
|
this.protocolPromise = new Promise((resolve): void => {
|
|
|
|
this.protoResolve = resolve;
|
|
|
|
});
|
2019-01-29 00:14:06 +07:00
|
|
|
this.pathSets = this.sharedProcessData.then((data) => {
|
2019-01-23 01:27:59 +07:00
|
|
|
paths._paths.socketPath = data.socketPath;
|
2019-01-29 00:14:06 +07:00
|
|
|
process.env.VSCODE_LOGS = data.logPath;
|
2019-01-23 01:27:59 +07:00
|
|
|
});
|
|
|
|
this.initData.then((data) => {
|
|
|
|
paths._paths.appData = data.dataDirectory;
|
|
|
|
paths._paths.defaultUserData = data.dataDirectory;
|
2019-01-29 00:14:06 +07:00
|
|
|
process.env.SHELL = data.shell;
|
2019-01-23 01:27:59 +07:00
|
|
|
});
|
2019-01-19 04:46:40 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
protected initialize(): Promise<void> {
|
|
|
|
registerContextMenuListener();
|
|
|
|
|
2019-01-23 01:27:59 +07:00
|
|
|
return this.task("Start workbench", 1000, async (data) => {
|
2019-01-19 04:46:40 +07:00
|
|
|
const { startup } = require("./startup");
|
|
|
|
await startup({
|
|
|
|
machineId: "1",
|
|
|
|
windowId: this.windowId,
|
|
|
|
logLevel: LogLevel.Info,
|
|
|
|
mainPid: 1,
|
2019-01-23 01:27:59 +07:00
|
|
|
appRoot: data.dataDirectory,
|
|
|
|
execPath: data.tmpDirectory,
|
2019-01-19 04:46:40 +07:00
|
|
|
userEnv: {},
|
2019-01-23 01:27:59 +07:00
|
|
|
nodeCachedDataDir: data.tmpDirectory,
|
2019-01-19 04:46:40 +07:00
|
|
|
perfEntries: [],
|
|
|
|
_: [],
|
2019-01-29 00:14:06 +07:00
|
|
|
folderUri: URI.file(data.workingDirectory),
|
2019-01-19 04:46:40 +07:00
|
|
|
});
|
|
|
|
|
2019-01-19 07:04:24 +07:00
|
|
|
// TODO: Set notification service for retrying.
|
|
|
|
// this.retry.setNotificationService({
|
|
|
|
// prompt: (severity, message, buttons, onCancel) => {
|
|
|
|
// const handle = getNotificationService().prompt(severity, message, buttons, onCancel);
|
|
|
|
// return {
|
|
|
|
// close: () => handle.close(),
|
|
|
|
// updateMessage: (message) => handle.updateMessage(message),
|
|
|
|
// updateButtons: (buttons) => handle.updateActions({
|
|
|
|
// primary: buttons.map((button) => ({
|
|
|
|
// id: undefined,
|
|
|
|
// label: button.label,
|
|
|
|
// tooltip: undefined,
|
|
|
|
// class: undefined,
|
|
|
|
// enabled: true,
|
|
|
|
// checked: false,
|
|
|
|
// radio: false,
|
|
|
|
// dispose: () => undefined,
|
|
|
|
// run: () => {
|
|
|
|
// button.run();
|
|
|
|
// return Promise.resolve();
|
|
|
|
// },
|
|
|
|
// })),
|
|
|
|
// }),
|
|
|
|
// };
|
|
|
|
// }
|
|
|
|
// });
|
|
|
|
|
2019-01-19 04:46:40 +07:00
|
|
|
// TODO: Set up clipboard context.
|
|
|
|
// const workbench = workbenchShell.workbench;
|
|
|
|
// const contextKeys = workbench.workbenchParams.serviceCollection.get(IContextKeyService) as IContextKeyService;
|
|
|
|
// const clipboardContextKey = new RawContextKey("nativeClipboard", this.clipboard.isSupported);
|
|
|
|
// const bounded = clipboardContextKey.bindTo(contextKeys);
|
|
|
|
// this.clipboard.onPermissionChange((enabled) => {
|
|
|
|
// bounded.set(enabled);
|
|
|
|
// });
|
|
|
|
this.clipboard.initialize();
|
2019-01-29 00:14:06 +07:00
|
|
|
}, this.initData, this.pathSets);
|
2019-01-19 04:46:40 +07:00
|
|
|
}
|
|
|
|
|
|
|
|
protected createUriFactory(): IURIFactory {
|
|
|
|
return {
|
|
|
|
// TODO: not sure why this is an error.
|
|
|
|
// tslint:disable-next-line no-any
|
|
|
|
create: <URI>(uri: IURI): URI => URI.from(uri) as any,
|
|
|
|
file: (path: string): IURI => URI.file(path),
|
|
|
|
parse: (raw: string): IURI => URI.parse(raw),
|
|
|
|
};
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
export const client = new Client();
|