32f85256d3
Manifest now holds exactly one agent and one effective bottle (with git_user overlay already applied). The old multi-agent/bottle collection is renamed ManifestIndex. BottleSpec.manifest starts as ManifestIndex from the CLI and becomes Manifest after _validate() calls load_for_agent(); all provisioning code downstream reads spec.manifest.agent / spec.manifest.bottle instead of indexing by name.
50 lines
1.6 KiB
Python
50 lines
1.6 KiB
Python
"""info: print env, skills, and prompt details for a named agent."""
|
|
|
|
from __future__ import annotations
|
|
|
|
import argparse
|
|
|
|
from ..log import info
|
|
from ..manifest import ManifestIndex
|
|
from ._common import PROG, USER_CWD
|
|
|
|
|
|
def cmd_info(argv: list[str]) -> int:
|
|
parser = argparse.ArgumentParser(prog=f"{PROG} info", add_help=True)
|
|
parser.add_argument("name", help="agent name defined in bot-bottle.json")
|
|
args = parser.parse_args(argv)
|
|
|
|
names = ManifestIndex.resolve(USER_CWD)
|
|
names.require_agent(args.name)
|
|
manifest = names.load_for_agent(args.name)
|
|
|
|
agent = manifest.agent
|
|
bottle = manifest.bottle
|
|
env_names = list(bottle.env.keys())
|
|
prompt_first_line = agent.prompt.splitlines()[0] if agent.prompt else ""
|
|
|
|
print()
|
|
info(f"agent : {args.name}")
|
|
info(f"env (names only): {', '.join(env_names) if env_names else '(none)'}")
|
|
info(f"skills : {' '.join(agent.skills) if agent.skills else '(none)'}")
|
|
info(
|
|
f"prompt : {len(agent.prompt)} chars; "
|
|
f"first line: {prompt_first_line or '(empty)'}"
|
|
)
|
|
info(f"bottle : {agent.bottle}")
|
|
identity = manifest.git_identity_summary()
|
|
if identity:
|
|
info(f" git identity : {identity}")
|
|
if bottle.git:
|
|
for e in bottle.git:
|
|
info(
|
|
f" git remote : {e.Name} -> {e.Upstream} "
|
|
f"(IdentityFile={e.IdentityFile})"
|
|
)
|
|
if e.KnownHostKey:
|
|
info(f" KnownHostKey: {e.KnownHostKey}")
|
|
else:
|
|
info(" git remotes : (none)")
|
|
print()
|
|
return 0
|