mirror of
https://github.com/QwenLM/qwen-code.git
synced 2026-04-28 19:52:02 +00:00
fix dependences of core pkg
This commit is contained in:
parent
06b64b07e7
commit
aa80e738fb
6 changed files with 58 additions and 47 deletions
1
package-lock.json
generated
1
package-lock.json
generated
|
|
@ -17987,6 +17987,7 @@
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@anthropic-ai/sdk": "^0.36.1",
|
"@anthropic-ai/sdk": "^0.36.1",
|
||||||
"@google/genai": "1.30.0",
|
"@google/genai": "1.30.0",
|
||||||
|
"@iarna/toml": "^2.2.5",
|
||||||
"@modelcontextprotocol/sdk": "^1.25.1",
|
"@modelcontextprotocol/sdk": "^1.25.1",
|
||||||
"@opentelemetry/api": "^1.9.0",
|
"@opentelemetry/api": "^1.9.0",
|
||||||
"@opentelemetry/exporter-logs-otlp-grpc": "^0.203.0",
|
"@opentelemetry/exporter-logs-otlp-grpc": "^0.203.0",
|
||||||
|
|
|
||||||
|
|
@ -23,6 +23,7 @@ vi.mock('./utils.js', () => ({
|
||||||
getLoadedExtensions: mockGetLoadedExtensions,
|
getLoadedExtensions: mockGetLoadedExtensions,
|
||||||
toOutputString: mockToOutputString,
|
toOutputString: mockToOutputString,
|
||||||
}),
|
}),
|
||||||
|
extensionToOutputString: mockToOutputString,
|
||||||
}));
|
}));
|
||||||
|
|
||||||
vi.mock('../../utils/errors.js', () => ({
|
vi.mock('../../utils/errors.js', () => ({
|
||||||
|
|
|
||||||
|
|
@ -6,7 +6,7 @@
|
||||||
|
|
||||||
import type { CommandModule } from 'yargs';
|
import type { CommandModule } from 'yargs';
|
||||||
import { getErrorMessage } from '../../utils/errors.js';
|
import { getErrorMessage } from '../../utils/errors.js';
|
||||||
import { getExtensionManager } from './utils.js';
|
import { extensionToOutputString, getExtensionManager } from './utils.js';
|
||||||
import { t } from '../../i18n/index.js';
|
import { t } from '../../i18n/index.js';
|
||||||
|
|
||||||
export async function handleList() {
|
export async function handleList() {
|
||||||
|
|
@ -21,7 +21,7 @@ export async function handleList() {
|
||||||
console.log(
|
console.log(
|
||||||
extensions
|
extensions
|
||||||
.map((extension, _): string =>
|
.map((extension, _): string =>
|
||||||
extensionManager.toOutputString(extension, process.cwd()),
|
extensionToOutputString(extension, extensionManager, process.cwd()),
|
||||||
)
|
)
|
||||||
.join('\n\n'),
|
.join('\n\n'),
|
||||||
);
|
);
|
||||||
|
|
|
||||||
|
|
@ -4,13 +4,15 @@
|
||||||
* SPDX-License-Identifier: Apache-2.0
|
* SPDX-License-Identifier: Apache-2.0
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import { ExtensionManager } from '@qwen-code/qwen-code-core';
|
import { ExtensionManager, type Extension } from '@qwen-code/qwen-code-core';
|
||||||
import { loadSettings } from '../../config/settings.js';
|
import { loadSettings } from '../../config/settings.js';
|
||||||
import {
|
import {
|
||||||
requestConsentOrFail,
|
requestConsentOrFail,
|
||||||
requestConsentNonInteractive,
|
requestConsentNonInteractive,
|
||||||
} from './consent.js';
|
} from './consent.js';
|
||||||
import { isWorkspaceTrusted } from '../../config/trustedFolders.js';
|
import { isWorkspaceTrusted } from '../../config/trustedFolders.js';
|
||||||
|
import * as os from 'node:os';
|
||||||
|
import chalk from 'chalk';
|
||||||
|
|
||||||
export async function getExtensionManager(): Promise<ExtensionManager> {
|
export async function getExtensionManager(): Promise<ExtensionManager> {
|
||||||
const workspaceDir = process.cwd();
|
const workspaceDir = process.cwd();
|
||||||
|
|
@ -25,3 +27,53 @@ export async function getExtensionManager(): Promise<ExtensionManager> {
|
||||||
await extensionManager.refreshCache();
|
await extensionManager.refreshCache();
|
||||||
return extensionManager;
|
return extensionManager;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export function extensionToOutputString(
|
||||||
|
extension: Extension,
|
||||||
|
extensionManager: ExtensionManager,
|
||||||
|
workspaceDir: string,
|
||||||
|
): string {
|
||||||
|
const cwd = workspaceDir;
|
||||||
|
const userEnabled = extensionManager.isEnabled(
|
||||||
|
extension.config.name,
|
||||||
|
os.homedir(),
|
||||||
|
);
|
||||||
|
const workspaceEnabled = extensionManager.isEnabled(
|
||||||
|
extension.config.name,
|
||||||
|
cwd,
|
||||||
|
);
|
||||||
|
|
||||||
|
const status = workspaceEnabled ? chalk.green('✓') : chalk.red('✗');
|
||||||
|
let output = `${status} ${extension.config.name} (${extension.config.version})`;
|
||||||
|
output += `\n Path: ${extension.path}`;
|
||||||
|
if (extension.installMetadata) {
|
||||||
|
output += `\n Source: ${extension.installMetadata.source} (Type: ${extension.installMetadata.type})`;
|
||||||
|
if (extension.installMetadata.ref) {
|
||||||
|
output += `\n Ref: ${extension.installMetadata.ref}`;
|
||||||
|
}
|
||||||
|
if (extension.installMetadata.releaseTag) {
|
||||||
|
output += `\n Release tag: ${extension.installMetadata.releaseTag}`;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
output += `\n Enabled (User): ${userEnabled}`;
|
||||||
|
output += `\n Enabled (Workspace): ${workspaceEnabled}`;
|
||||||
|
if (extension.contextFiles.length > 0) {
|
||||||
|
output += `\n Context files:`;
|
||||||
|
extension.contextFiles.forEach((contextFile) => {
|
||||||
|
output += `\n ${contextFile}`;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
if (extension.commands && extension.commands.length > 0) {
|
||||||
|
output += `\n Commands:`;
|
||||||
|
extension.commands.forEach((command) => {
|
||||||
|
output += `\n /${command}`;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
if (extension.config.mcpServers) {
|
||||||
|
output += `\n MCP servers:`;
|
||||||
|
Object.keys(extension.config.mcpServers).forEach((key) => {
|
||||||
|
output += `\n ${key}`;
|
||||||
|
});
|
||||||
|
}
|
||||||
|
return output;
|
||||||
|
}
|
||||||
|
|
|
||||||
|
|
@ -37,6 +37,7 @@
|
||||||
"@opentelemetry/sdk-node": "^0.203.0",
|
"@opentelemetry/sdk-node": "^0.203.0",
|
||||||
"@types/html-to-text": "^9.0.4",
|
"@types/html-to-text": "^9.0.4",
|
||||||
"@xterm/headless": "5.5.0",
|
"@xterm/headless": "5.5.0",
|
||||||
|
"@iarna/toml": "^2.2.5",
|
||||||
"ajv": "^8.17.1",
|
"ajv": "^8.17.1",
|
||||||
"ajv-formats": "^3.0.0",
|
"ajv-formats": "^3.0.0",
|
||||||
"async-mutex": "^0.5.0",
|
"async-mutex": "^0.5.0",
|
||||||
|
|
|
||||||
|
|
@ -36,7 +36,6 @@ import {
|
||||||
} from './github.js';
|
} from './github.js';
|
||||||
import type { LoadExtensionContext } from './variableSchema.js';
|
import type { LoadExtensionContext } from './variableSchema.js';
|
||||||
import { Override, type AllExtensionsEnablementConfig } from './override.js';
|
import { Override, type AllExtensionsEnablementConfig } from './override.js';
|
||||||
import chalk from 'chalk';
|
|
||||||
import { parseMarketplaceSource } from './marketplace.js';
|
import { parseMarketplaceSource } from './marketplace.js';
|
||||||
import {
|
import {
|
||||||
isGeminiExtensionConfig,
|
isGeminiExtensionConfig,
|
||||||
|
|
@ -1056,49 +1055,6 @@ export class ExtensionManager {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
|
||||||
* Converts an extension to output string.
|
|
||||||
*/
|
|
||||||
toOutputString(extension: Extension, workspaceDir?: string): string {
|
|
||||||
const cwd = workspaceDir ?? this.workspaceDir;
|
|
||||||
const userEnabled = this.isEnabled(extension.config.name, os.homedir());
|
|
||||||
const workspaceEnabled = this.isEnabled(extension.config.name, cwd);
|
|
||||||
|
|
||||||
const status = workspaceEnabled ? chalk.green('✓') : chalk.red('✗');
|
|
||||||
let output = `${status} ${extension.config.name} (${extension.config.version})`;
|
|
||||||
output += `\n Path: ${extension.path}`;
|
|
||||||
if (extension.installMetadata) {
|
|
||||||
output += `\n Source: ${extension.installMetadata.source} (Type: ${extension.installMetadata.type})`;
|
|
||||||
if (extension.installMetadata.ref) {
|
|
||||||
output += `\n Ref: ${extension.installMetadata.ref}`;
|
|
||||||
}
|
|
||||||
if (extension.installMetadata.releaseTag) {
|
|
||||||
output += `\n Release tag: ${extension.installMetadata.releaseTag}`;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
output += `\n Enabled (User): ${userEnabled}`;
|
|
||||||
output += `\n Enabled (Workspace): ${workspaceEnabled}`;
|
|
||||||
if (extension.contextFiles.length > 0) {
|
|
||||||
output += `\n Context files:`;
|
|
||||||
extension.contextFiles.forEach((contextFile) => {
|
|
||||||
output += `\n ${contextFile}`;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
if (extension.commands && extension.commands.length > 0) {
|
|
||||||
output += `\n Commands:`;
|
|
||||||
extension.commands.forEach((command) => {
|
|
||||||
output += `\n /${command}`;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
if (extension.config.mcpServers) {
|
|
||||||
output += `\n MCP servers:`;
|
|
||||||
Object.keys(extension.config.mcpServers).forEach((key) => {
|
|
||||||
output += `\n ${key}`;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
return output;
|
|
||||||
}
|
|
||||||
|
|
||||||
async performWorkspaceExtensionMigration(
|
async performWorkspaceExtensionMigration(
|
||||||
extensions: Extension[],
|
extensions: Extension[],
|
||||||
requestConsent: (options?: ExtensionRequestOptions) => Promise<void>,
|
requestConsent: (options?: ExtensionRequestOptions) => Promise<void>,
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue