vscode/scripts/code-web.js

168 lines
5.1 KiB
JavaScript
Raw Normal View History

/*---------------------------------------------------------------------------------------------
* Copyright (c) Microsoft Corporation. All rights reserved.
* Licensed under the MIT License. See License.txt in the project root for license information.
*--------------------------------------------------------------------------------------------*/
// @ts-check
2022-02-03 00:48:36 +08:00
const testWebLocation = require.resolve('@vscode/test-web');
const fs = require('fs');
const path = require('path');
2022-02-03 00:48:36 +08:00
const cp = require('child_process');
const minimist = require('minimist');
const fancyLog = require('fancy-log');
const ansiColors = require('ansi-colors');
const open = require('open');
const https = require('https');
const APP_ROOT = path.join(__dirname, '..');
const WEB_DEV_EXTENSIONS_ROOT = path.join(APP_ROOT, '.build', 'builtInWebDevExtensions');
const WEB_PLAYGROUND_VERSION = '0.0.13';
2022-02-03 00:48:36 +08:00
async function main() {
const args = minimist(process.argv.slice(2), {
boolean: [
'help',
'playground'
],
string: [
'host',
'port',
'extensionPath',
2022-02-03 18:26:53 +08:00
'browser',
2022-02-03 00:48:36 +08:00
'browserType'
],
});
if (args.help) {
console.log(
'./scripts/code-web.sh|bat[, folderMountPath[, options]]\n' +
' Start with an empty workspace and no folder opened in explorer\n' +
' folderMountPath Open local folder (eg: use `.` to open current directory)\n' +
' --playground Include the vscode-web-playground extension\n'
2022-02-03 00:48:36 +08:00
);
startServer(['--help']);
2022-02-03 00:53:24 +08:00
return;
2022-02-03 00:48:36 +08:00
}
2022-02-03 00:48:36 +08:00
const serverArgs = [];
2022-02-03 00:48:36 +08:00
const HOST = args['host'] ?? 'localhost';
const PORT = args['port'] ?? '8080';
2022-02-03 00:48:36 +08:00
if (args['host'] === undefined) {
serverArgs.push('--host', HOST);
}
if (args['port'] === undefined) {
serverArgs.push('--port', PORT);
}
// only use `./scripts/code-web.sh --playground` to add vscode-web-playground extension by default.
if (args['playground'] === true) {
2022-02-03 00:48:36 +08:00
serverArgs.push('--extensionPath', WEB_DEV_EXTENSIONS_ROOT);
serverArgs.push('--folder-uri', 'memfs:///sample-folder');
2022-02-03 01:55:40 +08:00
await ensureWebDevExtensions(args['verbose']);
2022-02-03 00:48:36 +08:00
}
2022-02-03 00:48:36 +08:00
let openSystemBrowser = false;
2022-02-03 18:26:53 +08:00
if (!args['browser'] && !args['browserType']) {
serverArgs.push('--browserType', 'none');
2022-02-03 00:48:36 +08:00
openSystemBrowser = true;
}
serverArgs.push('--sourcesPath', APP_ROOT);
2022-02-04 20:21:12 +08:00
serverArgs.push(...process.argv.slice(2).filter(v => !v.startsWith('--playground') && v !== '--no-playground'));
2022-02-03 00:48:36 +08:00
startServer(serverArgs);
if (openSystemBrowser) {
open(`http://${HOST}:${PORT}/`);
}
}
2022-02-03 00:48:36 +08:00
function startServer(runnerArguments) {
const env = { ...process.env };
console.log(`Starting @vscode/test-web: ${testWebLocation} ${runnerArguments.join(' ')}`);
const proc = cp.spawn(process.execPath, [testWebLocation, ...runnerArguments], { env, stdio: 'inherit' });
proc.on('exit', (code) => process.exit(code));
process.on('exit', () => proc.kill());
process.on('SIGINT', () => {
proc.kill();
process.exit(128 + 2); // https://nodejs.org/docs/v14.16.0/api/process.html#process_signal_events
});
process.on('SIGTERM', () => {
proc.kill();
process.exit(128 + 15); // https://nodejs.org/docs/v14.16.0/api/process.html#process_signal_events
});
}
async function directoryExists(path) {
try {
return (await fs.promises.stat(path)).isDirectory();
} catch {
return false;
}
}
/** @return {Promise<void>} */
async function downloadPlaygroundFile(fileName, httpsLocation, destinationRoot) {
const destination = path.join(destinationRoot, fileName);
await fs.promises.mkdir(path.dirname(destination), { recursive: true });
const fileStream = fs.createWriteStream(destination);
return (new Promise((resolve, reject) => {
const request = https.get(path.posix.join(httpsLocation, fileName), response => {
response.pipe(fileStream);
fileStream.on('finish', () => {
fileStream.close();
resolve();
});
});
request.on('error', reject);
}));
}
2022-02-03 00:48:36 +08:00
async function ensureWebDevExtensions(verbose) {
// Playground (https://github.com/microsoft/vscode-web-playground)
const webDevPlaygroundRoot = path.join(WEB_DEV_EXTENSIONS_ROOT, 'vscode-web-playground');
const webDevPlaygroundExists = await directoryExists(webDevPlaygroundRoot);
let downloadPlayground = false;
if (webDevPlaygroundExists) {
try {
const webDevPlaygroundPackageJson = JSON.parse(((await fs.promises.readFile(path.join(webDevPlaygroundRoot, 'package.json'))).toString()));
if (webDevPlaygroundPackageJson.version !== WEB_PLAYGROUND_VERSION) {
downloadPlayground = true;
}
} catch (error) {
downloadPlayground = true;
}
} else {
downloadPlayground = true;
}
if (downloadPlayground) {
2022-02-03 00:48:36 +08:00
if (verbose) {
fancyLog(`${ansiColors.magenta('Web Development extensions')}: Downloading vscode-web-playground to ${webDevPlaygroundRoot}`);
}
const playgroundRepo = `https://raw.githubusercontent.com/microsoft/vscode-web-playground/main/`;
await Promise.all(['package.json', 'dist/extension.js', 'dist/extension.js.map'].map(
fileName => downloadPlaygroundFile(fileName, playgroundRepo, webDevPlaygroundRoot)
));
} else {
2022-02-03 00:48:36 +08:00
if (verbose) {
fancyLog(`${ansiColors.magenta('Web Development extensions')}: Using existing vscode-web-playground in ${webDevPlaygroundRoot}`);
}
}
}
2022-02-03 00:48:36 +08:00
main();