vscode/scripts/xterm-update.js
2024-04-26 05:54:23 -07:00

99 lines
3.1 KiB
JavaScript

/*---------------------------------------------------------------------------------------------
* Copyright (c) Microsoft Corporation. All rights reserved.
* Licensed under the MIT License. See License.txt in the project root for license information.
*--------------------------------------------------------------------------------------------*/
const cp = require('child_process');
const path = require('path');
const moduleNames = [
'@xterm/xterm',
'@xterm/addon-image',
'@xterm/addon-search',
'@xterm/addon-serialize',
'@xterm/addon-unicode11',
'@xterm/addon-webgl',
];
const backendOnlyModuleNames = [
'@xterm/headless'
];
const vscodeDir = process.argv.length >= 3 ? process.argv[2] : process.cwd();
if (path.basename(vscodeDir) !== 'vscode') {
console.error('The cwd is not named "vscode"');
return;
}
function getLatestModuleVersion(moduleName) {
return new Promise((resolve, reject) => {
cp.exec(`npm view ${moduleName} versions --json`, { cwd: vscodeDir }, (err, stdout, stderr) => {
if (err) {
reject(err);
}
let versions = JSON.parse(stdout);
// Fix format if there is only a single version published
if (typeof versions === 'string') {
versions = [versions];
}
resolve(versions[versions.length - 1]);
});
});
}
async function update() {
console.log('Fetching latest versions');
const allModules = moduleNames.concat(backendOnlyModuleNames);
const versionPromises = [];
for (const m of allModules) {
versionPromises.push(getLatestModuleVersion(m));
}
const latestVersionsArray = await Promise.all(versionPromises);
const latestVersions = {};
for (const [i, v] of latestVersionsArray.entries()) {
latestVersions[allModules[i]] = v;
}
console.log('Detected versions:');
for (const m of moduleNames.concat(backendOnlyModuleNames)) {
console.log(` ${m}@${latestVersions[m]}`);
}
const pkg = require(path.join(vscodeDir, 'package.json'));
const modulesWithVersion = [];
for (const m of moduleNames) {
const moduleWithVersion = `${m}@${latestVersions[m]}`;
if (pkg.dependencies[m] === latestVersions[m]) {
console.log(`Skipping ${moduleWithVersion}, already up to date`);
continue;
}
modulesWithVersion.push(moduleWithVersion);
}
if (modulesWithVersion.length > 0) {
for (const cwd of [vscodeDir, path.join(vscodeDir, 'remote'), path.join(vscodeDir, 'remote/web')]) {
console.log(`${path.join(cwd, 'package.json')}: Updating\n ${modulesWithVersion.join('\n ')}`);
cp.execSync(`yarn add ${modulesWithVersion.join(' ')}`, { cwd });
}
}
const backendOnlyModulesWithVersion = [];
for (const m of backendOnlyModuleNames) {
const moduleWithVersion = `${m}@${latestVersions[m]}`;
if (pkg.dependencies[m] === latestVersions[m]) {
console.log(`Skipping ${moduleWithVersion}, already up to date`);
continue;
}
backendOnlyModulesWithVersion.push(moduleWithVersion);
}
if (backendOnlyModulesWithVersion.length > 0) {
for (const cwd of [vscodeDir, path.join(vscodeDir, 'remote')]) {
console.log(`${path.join(cwd, 'package.json')}: Updating\n ${backendOnlyModulesWithVersion.join('\n ')}`);
cp.execSync(`yarn add ${backendOnlyModulesWithVersion.join(' ')}`, { cwd });
}
}
}
update();