diff options
| author | Michelle Tilley <michelle@michelletilley.net> | 2026-04-23 13:43:01 -0700 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2026-04-23 13:43:01 -0700 |
| commit | 461ef4c43589c6ca68176c180fd04f2755c9f036 (patch) | |
| tree | c646ea272d6016533c4941592f9a22baa2a54488 /crates/atuin-ai/src/fsm/mod.rs | |
| parent | feat: Send user-defined context with `TERMINAL.md` (#3443) (diff) | |
| download | atuin-461ef4c43589c6ca68176c180fd04f2755c9f036.zip | |
feat: Add skill discovery, loading, and invocation (#3444)
Adds a skills system that lets users define reusable LLM instructions as `SKILL.md` files with YAML frontmatter.
Diffstat (limited to 'crates/atuin-ai/src/fsm/mod.rs')
| -rw-r--r-- | crates/atuin-ai/src/fsm/mod.rs | 50 |
1 files changed, 50 insertions, 0 deletions
diff --git a/crates/atuin-ai/src/fsm/mod.rs b/crates/atuin-ai/src/fsm/mod.rs index 25de41f3..3d72a3ae 100644 --- a/crates/atuin-ai/src/fsm/mod.rs +++ b/crates/atuin-ai/src/fsm/mod.rs @@ -309,6 +309,33 @@ impl AgentFsm { vec![] } + ( + AgentState::Idle { .. }, + Event::SkillLoaded { + name, + arguments, + content, + }, + ) => { + self.ctx.events.push(ConversationEvent::SkillInvocation { + name, + arguments, + content, + }); + self.ctx.current_response.clear(); + self.ctx.current_turn_tool_ids.clear(); + + let messages = self.build_messages(); + let session_id = self.ctx.session_id.clone(); + self.state = AgentState::Turn { + stream: StreamPhase::Connecting, + }; + vec![Effect::StartStream { + messages, + session_id, + }] + } + // ================================================================ // Turn — stream lifecycle // ================================================================ @@ -584,6 +611,29 @@ impl AgentFsm { vec![] } + // RequestSkillLoad during non-idle: still emit the effect + (_, Event::RequestSkillLoad { name, arguments }) => { + vec![Effect::LoadSkill { name, arguments }] + } + + // SkillLoaded during non-idle: queue so it's visible + // in context for the next turn. + ( + _, + Event::SkillLoaded { + name, + arguments, + content, + }, + ) => { + self.ctx.events.push(ConversationEvent::SkillInvocation { + name, + arguments, + content, + }); + vec![] + } + _ => vec![], } } |
