Add arguments for ports

This commit is contained in:
Asher 2019-07-02 18:29:48 -05:00
parent 770e0db7b8
commit 61c281ec6b
No known key found for this signature in database
GPG Key ID: D63C1EF81242354A
1 changed files with 12 additions and 4 deletions

16
cli.ts
View File

@ -2,18 +2,26 @@ import * as os from "os";
import { validatePaths } from "vs/code/node/paths"; import { validatePaths } from "vs/code/node/paths";
import { parseMainProcessArgv } from "vs/platform/environment/node/argvHelper"; import { parseMainProcessArgv } from "vs/platform/environment/node/argvHelper";
import { ParsedArgs } from "vs/platform/environment/common/environment"; import { ParsedArgs } from "vs/platform/environment/common/environment";
import { buildHelpMessage, buildVersionMessage } from "vs/platform/environment/node/argv"; import { buildHelpMessage, buildVersionMessage, options } from "vs/platform/environment/node/argv";
import product from "vs/platform/product/node/product"; import product from "vs/platform/product/node/product";
import pkg from "vs/platform/product/node/package"; import pkg from "vs/platform/product/node/package";
import { MainServer, WebviewServer } from "vs/server/server"; import { MainServer, WebviewServer } from "vs/server/server";
import "vs/server/tar"; import "vs/server/tar";
interface Args extends ParsedArgs {
port?: string;
"webview-port"?: string;
}
options.push({ id: "port", type: "string", cat: "o", description: "Port for the main server." });
options.push({ id: "webview-port", type: "string", cat: "o", description: "Port for the webview server." });
interface IMainCli { interface IMainCli {
main: (argv: ParsedArgs) => Promise<void>; main: (argv: ParsedArgs) => Promise<void>;
} }
const main = async (): Promise<void> => { const main = async (): Promise<void> => {
const args = validatePaths(parseMainProcessArgv(process.argv)); const args = validatePaths(parseMainProcessArgv(process.argv)) as Args;
if (!product.extensionsGallery) { if (!product.extensionsGallery) {
product.extensionsGallery = { product.extensionsGallery = {
@ -53,8 +61,8 @@ const main = async (): Promise<void> => {
const server = new MainServer(webviewServer, args); const server = new MainServer(webviewServer, args);
// The main server inserts webview server address to the root HTML, so we'll // The main server inserts webview server address to the root HTML, so we'll
// need to wait for it to listen otherwise the address will be null. // need to wait for it to listen otherwise the address will be null.
await webviewServer.listen(8444); await webviewServer.listen(typeof args["webview-port"] !== "undefined" && parseInt(args["webview-port"], 10) || 8444);
await server.listen(8443); await server.listen(typeof args.port !== "undefined" && parseInt(args.port, 10) || 8443);
console.log(`Main server serving ${server.address}`); console.log(`Main server serving ${server.address}`);
console.log(`Webview server serving ${webviewServer.address}`); console.log(`Webview server serving ${webviewServer.address}`);
}; };