mirror of
https://github.com/getcompanion-ai/co-mono.git
synced 2026-04-15 20:03:05 +00:00
feat(coding-agent): allow explicit -e flags with --no-extensions
--no-extensions now skips discovery but still loads extensions specified via -e flags. This gives users three modes: 1. Default: auto-discover + any -e additions 2. --no-extensions: no extensions at all 3. --no-extensions -e foo.js: only load foo.js, skip discovery fixes #524
This commit is contained in:
parent
48f524c554
commit
499341cdc1
3 changed files with 51 additions and 2 deletions
|
|
@ -18,7 +18,12 @@ import type { AgentSession } from "./core/agent-session.js";
|
|||
|
||||
import { createEventBus } from "./core/event-bus.js";
|
||||
import { exportFromFile } from "./core/export-html/index.js";
|
||||
import { discoverAndLoadExtensions, type ExtensionUIContext, type LoadedExtension } from "./core/extensions/index.js";
|
||||
import {
|
||||
discoverAndLoadExtensions,
|
||||
type ExtensionUIContext,
|
||||
type LoadedExtension,
|
||||
loadExtensions,
|
||||
} from "./core/extensions/index.js";
|
||||
import type { ModelRegistry } from "./core/model-registry.js";
|
||||
import { resolveModelScope, type ScopedModel } from "./core/model-resolver.js";
|
||||
import { type CreateAgentSessionOptions, createAgentSession, discoverAuthStorage, discoverModels } from "./core/sdk.js";
|
||||
|
|
@ -328,7 +333,15 @@ export async function main(args: string[]) {
|
|||
time("SettingsManager.create");
|
||||
|
||||
let loadedExtensions: LoadedExtension[] = [];
|
||||
if (!firstPass.noExtensions) {
|
||||
if (firstPass.noExtensions) {
|
||||
// --no-extensions disables discovery, but explicit -e flags still work
|
||||
const explicitPaths = firstPass.extensions ?? [];
|
||||
if (explicitPaths.length > 0) {
|
||||
const result = await loadExtensions(explicitPaths, cwd, eventBus);
|
||||
loadedExtensions = result.extensions;
|
||||
time("loadExtensions");
|
||||
}
|
||||
} else {
|
||||
// Merge CLI --extension args with settings.json extensions
|
||||
const extensionPaths = [...settingsManager.getExtensionPaths(), ...(firstPass.extensions ?? [])];
|
||||
const result = await discoverAndLoadExtensions(extensionPaths, cwd, agentDir, eventBus);
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue