Skip to main content

ai_agent/types/
tools.rs

1// Source: ~/claudecode/openclaudecode/src/types/tools.rs
2
3use serde::{Deserialize, Serialize};
4
5/// Trait for tool structs that provide render/display metadata.
6/// All built-in tool structs implement this trait, enabling agent.rs
7/// to construct `ToolRenderFns` without hardcoded display logic.
8pub trait ToolRender: Send + Sync {
9    fn user_facing_name(&self, input: Option<&serde_json::Value>) -> String;
10    fn get_tool_use_summary(&self, input: Option<&serde_json::Value>) -> Option<String>;
11    fn render_tool_result_message(&self, content: &serde_json::Value) -> Option<String>;
12}
13
14/// Base tool progress data with flexible extra fields.
15#[derive(Debug, Clone, Serialize, Deserialize)]
16pub struct ToolProgressData {
17    #[serde(rename = "kind", skip_serializing_if = "Option::is_none")]
18    pub kind: Option<String>,
19    #[serde(flatten)]
20    pub extra: std::collections::HashMap<String, serde_json::Value>,
21}
22
23/// Progress types for various tools, all sharing ToolProgressData structure.
24pub type ShellProgress = ToolProgressData;
25pub type BashProgress = ToolProgressData;
26pub type PowerShellProgress = ToolProgressData;
27pub type McpProgress = ToolProgressData;
28pub type SkillToolProgress = ToolProgressData;
29pub type TaskOutputProgress = ToolProgressData;
30pub type WebSearchProgress = ToolProgressData;
31pub type AgentToolProgress = ToolProgressData;
32pub type ReplToolProgress = ToolProgressData;
33pub type SdkWorkflowProgress = ToolProgressData;