Squash the imported source snapshot and follow-up documentation history into one root commit so the archive starts from a single coherent state. Constraint: Repository intentionally tracks an analyzed Claude Code source snapshot Constraint: Author and committer must be instructkr <no-contact@instruct.kr> Rejected: Preserve the four-step import/docs history | user explicitly requested one squashed commit Confidence: high Scope-risk: broad Reversibility: clean Directive: Keep future analysis and refactor commits separate from this archive baseline Tested: git status clean; local history rewritten to one commit; force-pushed main to origin and instructkr Not-tested: Fresh clone verification after push
71 lines
2.0 KiB
TypeScript
71 lines
2.0 KiB
TypeScript
/**
|
|
* Agents subcommand handler — prints the list of configured agents.
|
|
* Dynamically imported only when `claude agents` runs.
|
|
*/
|
|
|
|
import {
|
|
AGENT_SOURCE_GROUPS,
|
|
compareAgentsByName,
|
|
getOverrideSourceLabel,
|
|
type ResolvedAgent,
|
|
resolveAgentModelDisplay,
|
|
resolveAgentOverrides,
|
|
} from '../../tools/AgentTool/agentDisplay.js'
|
|
import {
|
|
getActiveAgentsFromList,
|
|
getAgentDefinitionsWithOverrides,
|
|
} from '../../tools/AgentTool/loadAgentsDir.js'
|
|
import { getCwd } from '../../utils/cwd.js'
|
|
|
|
function formatAgent(agent: ResolvedAgent): string {
|
|
const model = resolveAgentModelDisplay(agent)
|
|
const parts = [agent.agentType]
|
|
if (model) {
|
|
parts.push(model)
|
|
}
|
|
if (agent.memory) {
|
|
parts.push(`${agent.memory} memory`)
|
|
}
|
|
return parts.join(' · ')
|
|
}
|
|
|
|
export async function agentsHandler(): Promise<void> {
|
|
const cwd = getCwd()
|
|
const { allAgents } = await getAgentDefinitionsWithOverrides(cwd)
|
|
const activeAgents = getActiveAgentsFromList(allAgents)
|
|
const resolvedAgents = resolveAgentOverrides(allAgents, activeAgents)
|
|
|
|
const lines: string[] = []
|
|
let totalActive = 0
|
|
|
|
for (const { label, source } of AGENT_SOURCE_GROUPS) {
|
|
const groupAgents = resolvedAgents
|
|
.filter(a => a.source === source)
|
|
.sort(compareAgentsByName)
|
|
|
|
if (groupAgents.length === 0) continue
|
|
|
|
lines.push(`${label}:`)
|
|
for (const agent of groupAgents) {
|
|
if (agent.overriddenBy) {
|
|
const winnerSource = getOverrideSourceLabel(agent.overriddenBy)
|
|
lines.push(` (shadowed by ${winnerSource}) ${formatAgent(agent)}`)
|
|
} else {
|
|
lines.push(` ${formatAgent(agent)}`)
|
|
totalActive++
|
|
}
|
|
}
|
|
lines.push('')
|
|
}
|
|
|
|
if (lines.length === 0) {
|
|
// biome-ignore lint/suspicious/noConsole:: intentional console output
|
|
console.log('No agents found.')
|
|
} else {
|
|
// biome-ignore lint/suspicious/noConsole:: intentional console output
|
|
console.log(`${totalActive} active agents\n`)
|
|
// biome-ignore lint/suspicious/noConsole:: intentional console output
|
|
console.log(lines.join('\n').trimEnd())
|
|
}
|
|
}
|