mirror of
https://github.com/microsoft/vscode.git
synced 2026-05-16 13:21:04 +01:00
e8a7c6d6df
* Stop copying node-pty into Copilot CLI SDK * reanem Co-authored-by: Copilot <copilot@github.com> * resovle copilot comment * recognize other sdk prebuilds NOT node-pty Co-authored-by: Copilot <copilot@github.com> --------- Co-authored-by: Copilot <copilot@github.com>
111 lines
4.8 KiB
TypeScript
111 lines
4.8 KiB
TypeScript
/*---------------------------------------------------------------------------------------------
|
|
* Copyright (c) Microsoft Corporation. All rights reserved.
|
|
* Licensed under the MIT License. See License.txt in the project root for license information.
|
|
*--------------------------------------------------------------------------------------------*/
|
|
|
|
import * as fs from 'fs';
|
|
import * as path from 'path';
|
|
|
|
/**
|
|
* The platforms that @github/copilot ships platform-specific packages for.
|
|
* These are the `@github/copilot-{platform}` optional dependency packages.
|
|
*/
|
|
export const copilotPlatforms = [
|
|
'darwin-arm64', 'darwin-x64',
|
|
'linux-arm64', 'linux-x64',
|
|
'win32-arm64', 'win32-x64',
|
|
];
|
|
|
|
/**
|
|
* Converts VS Code build platform/arch to the values that Node.js reports
|
|
* at runtime via `process.platform` and `process.arch`.
|
|
*
|
|
* The copilot SDK's `loadNativeModule` looks up native binaries under
|
|
* `prebuilds/${process.platform}-${process.arch}/`, so the directory names
|
|
* must match these runtime values exactly.
|
|
*/
|
|
function toNodePlatformArch(platform: string, arch: string): { nodePlatform: string; nodeArch: string } {
|
|
// alpine is musl-linux; Node still reports process.platform === 'linux'
|
|
let nodePlatform = platform === 'alpine' ? 'linux' : platform;
|
|
let nodeArch = arch;
|
|
|
|
if (arch === 'armhf') {
|
|
// VS Code build uses 'armhf'; Node reports process.arch === 'arm'
|
|
nodeArch = 'arm';
|
|
} else if (arch === 'alpine') {
|
|
// Legacy: { platform: 'linux', arch: 'alpine' } means alpine-x64
|
|
nodePlatform = 'linux';
|
|
nodeArch = 'x64';
|
|
}
|
|
|
|
return { nodePlatform, nodeArch };
|
|
}
|
|
|
|
/**
|
|
* Returns a glob filter that strips @github/copilot platform packages
|
|
* for architectures other than the build target.
|
|
*
|
|
* For platforms the copilot SDK doesn't natively support (e.g. alpine, armhf),
|
|
* ALL platform packages are stripped - that's fine because the copilot CLI SDK
|
|
* resolves `node-pty` from the embedder (VS Code) first via `hostRequire`,
|
|
* falling back to its bundled copy only if the embedder can't provide it.
|
|
*/
|
|
export function getCopilotExcludeFilter(platform: string, arch: string): string[] {
|
|
const { nodePlatform, nodeArch } = toNodePlatformArch(platform, arch);
|
|
const targetPlatformArch = `${nodePlatform}-${nodeArch}`;
|
|
const nonTargetPlatforms = copilotPlatforms.filter(p => p !== targetPlatformArch);
|
|
|
|
// Strip wrong-architecture @github/copilot-{platform} packages.
|
|
// All copilot prebuilds are stripped by .moduleignore; the copilot CLI SDK
|
|
// resolves `node-pty` from VS Code's own node_modules via `hostRequire`.
|
|
const excludes = nonTargetPlatforms.map(p => `!**/node_modules/@github/copilot-${p}/**`);
|
|
|
|
return ['**', ...excludes];
|
|
}
|
|
|
|
/**
|
|
* Materializes the copilot CLI ripgrep shim directly inside the built-in copilot extension.
|
|
*
|
|
* This is used when copilot is shipped as a built-in extension so startup does
|
|
* not need to create the shim at runtime. The destination layout matches the
|
|
* runtime shim logic in the copilot extension:
|
|
* - ripgrep: node_modules/@github/copilot/sdk/ripgrep/bin/{platform-arch}
|
|
* - marker: node_modules/@github/copilot/shims.txt
|
|
*
|
|
* Note: `node-pty` is no longer shimmed. The copilot CLI SDK resolves
|
|
* `node-pty` from the embedder (VS Code) via `hostRequire` and falls back to
|
|
* its bundled copy only if that fails.
|
|
*
|
|
* Failures throw to fail the build because built-in packaging must guarantee
|
|
* this artifact is present.
|
|
*/
|
|
export function prepareBuiltInCopilotRipgrepShim(platform: string, arch: string, builtInCopilotExtensionDir: string, appNodeModulesDir: string): void {
|
|
const { nodePlatform, nodeArch } = toNodePlatformArch(platform, arch);
|
|
const platformArch = `${nodePlatform}-${nodeArch}`;
|
|
|
|
const extensionNodeModules = path.join(builtInCopilotExtensionDir, 'node_modules');
|
|
const copilotBase = path.join(extensionNodeModules, '@github', 'copilot');
|
|
const copilotSdkBase = path.join(copilotBase, 'sdk');
|
|
if (!fs.existsSync(copilotSdkBase)) {
|
|
throw new Error(`[prepareBuiltInCopilotRipgrepShim] Copilot SDK directory not found at ${copilotSdkBase}`);
|
|
}
|
|
|
|
const ripgrepSource = path.join(appNodeModulesDir, '@vscode', 'ripgrep', 'bin');
|
|
if (!fs.existsSync(ripgrepSource)) {
|
|
throw new Error(`[prepareBuiltInCopilotRipgrepShim] ripgrep source not found at ${ripgrepSource}`);
|
|
}
|
|
|
|
const ripgrepDest = path.join(copilotSdkBase, 'ripgrep', 'bin', platformArch);
|
|
const shimMarkerPath = path.join(copilotBase, 'shims.txt');
|
|
|
|
try {
|
|
fs.mkdirSync(ripgrepDest, { recursive: true });
|
|
fs.cpSync(ripgrepSource, ripgrepDest, { recursive: true });
|
|
|
|
fs.writeFileSync(shimMarkerPath, 'Shims created successfully');
|
|
console.log(`[prepareBuiltInCopilotRipgrepShim] Materialized ripgrep shim for ${platformArch} in ${builtInCopilotExtensionDir}`);
|
|
} catch (err) {
|
|
throw new Error(`[prepareBuiltInCopilotRipgrepShim] Failed to materialize ripgrep shim for ${platformArch}: ${err}`);
|
|
}
|
|
}
|