Skip to main content

Tool

Struct Tool 

Source
pub struct Tool { /* private fields */ }
Expand description

The tool call structure

Implementations§

Source§

impl Tool

Source

pub fn new( name: impl Into<String>, descr: impl Into<String>, schema: Schema, ) -> Self

Creates a new tool call

Examples found in repository?
examples/lmstudio-tools.rs (lines 15-20)
4async fn main() -> Result<()> {
5    /// The weather tool data
6    #[allow(dead_code)]
7    #[derive(Debug, serde::Deserialize)]
8    struct LocationData {
9        location: String,
10    }
11
12    // send request:
13    let mut response = Completions::lmstudio("", "qwen/qwen3-vl-4b")
14        .user_message(vec!["What's the weather like in London?".into()])
15        .tool(Tool::new(
16            "weather",
17            "Search weather by location",
18            Schema::object("Location data")
19                .required_property("location", Schema::string("The location")),
20        ))
21        .send()
22        .await?;
23
24    // read response stream:
25    let mut tool_calls = vec![];
26    while let Some(chunk) = response.next().await {
27        match chunk? {
28            Chunk::Text(text) => {
29                eprint!("{text}");
30            }
31            Chunk::Tool(name, json_str) => {
32                tool_calls.push((name, json_str));
33            }
34        }
35    }
36    println!();
37
38    // handle tool calls:
39    for (name, json_str) in tool_calls {
40        match name.as_ref() {
41            "weather" => {
42                let location: LocationData = serde_json::from_str(&json_str)?;
43                println!("{location:#?}");
44            }
45            _ => {}
46        }
47    }
48
49    Ok(())
50}
More examples
Hide additional examples
examples/lmstudio-schema.rs (lines 15-20)
4async fn main() -> Result<()> {
5    /// The weather tool data
6    #[allow(dead_code)]
7    #[derive(Debug, serde::Deserialize)]
8    struct LocationData {
9        location: String,
10    }
11
12    // send request:
13    let mut response = Completions::lmstudio("", "mistralai/ministral-3-3b")
14        .user_message(vec!["What's the weather like in London?".into()])
15        .tool(Tool::new(
16            "weather",
17            "Search weather by location",
18            Schema::object("Location data")
19                .required_property("location", Schema::string("The location")),
20        ))
21        .send()
22        .await?;
23
24    // read response stream:
25    let mut tool_calls = vec![];
26    while let Some(chunk) = response.next().await {
27        match chunk? {
28            Chunk::Text(text) => {
29                eprint!("{text}");
30            }
31            Chunk::Tool(name, json_str) => {
32                tool_calls.push((name, json_str));
33            }
34        }
35    }
36    println!();
37
38    // handle tool calls:
39    for (name, json_str) in tool_calls {
40        match name.as_ref() {
41            "weather" => {
42                let location: LocationData = serde_json::from_str(&json_str)?;
43                println!("{location:#?}");
44            }
45            _ => {}
46        }
47    }
48
49    Ok(())
50}
examples/cerebras-tools.rs (lines 18-23)
4async fn main() -> Result<()> {
5    let api_key = std::env::var("CEREBRAS_API_KEY")?;
6
7    /// The weather tool data
8    #[allow(dead_code)]
9    #[derive(Debug, serde::Deserialize)]
10    struct LocationData {
11        location: String,
12    }
13
14    // send request:
15    let mut response = Completions::cerebras(api_key, "llama3.1-8b")
16        .proxy(Proxy::all("socks5://127.0.0.1:1080")?)
17        .user_message(vec!["What's the weather like in London?".into()])
18        .tool(Tool::new(
19            "weather",
20            "Search weather by location",
21            Schema::object("Location data")
22                .required_property("location", Schema::string("The location")),
23        ))
24        .send()
25        .await?;
26
27    // read response stream:
28    let mut tool_calls = vec![];
29    while let Some(chunk) = response.next().await {
30        match chunk? {
31            Chunk::Text(text) => {
32                eprint!("{text}");
33            }
34            Chunk::Tool(name, json_str) => {
35                tool_calls.push((name, json_str));
36            }
37        }
38    }
39    println!();
40
41    // handle tool calls:
42    for (name, json_str) in tool_calls {
43        match name.as_ref() {
44            "weather" => {
45                let location: LocationData = serde_json::from_str(&json_str)?;
46                println!("{location:#?}");
47            }
48            _ => {}
49        }
50    }
51
52    Ok(())
53}
examples/anthropic-tools.rs (lines 18-23)
4async fn main() -> Result<()> {
5    let api_key = std::env::var("ANTHROPIC_API_KEY")?;
6
7    /// The weather tool data
8    #[allow(dead_code)]
9    #[derive(Debug, serde::Deserialize)]
10    struct LocationData {
11        location: String,
12    }
13
14    // send request:
15    let mut response = Completions::anthropic(api_key, "claude-opus-4-6")
16        .proxy(Proxy::all("socks5://127.0.0.1:1080")?)
17        .user_message(vec!["What's the weather like in London?".into()])
18        .tool(Tool::new(
19            "weather",
20            "Search weather by location",
21            Schema::object("Location data")
22                .required_property("location", Schema::string("The location")),
23        ))
24        .send()
25        .await?;
26
27    // read response stream:
28    let mut tool_calls = vec![];
29    while let Some(chunk) = response.next().await {
30        match chunk? {
31            Chunk::Text(text) => {
32                eprint!("{text}");
33            }
34            Chunk::Tool(name, json_str) => {
35                tool_calls.push((name, json_str));
36            }
37        }
38    }
39    println!();
40
41    // handle tool calls:
42    for (name, json_str) in tool_calls {
43        match name.as_ref() {
44            "weather" => {
45                let location: LocationData = serde_json::from_str(&json_str)?;
46                println!("{location:#?}");
47            }
48            _ => {}
49        }
50    }
51
52    Ok(())
53}
examples/openrouter-tools.rs (lines 18-23)
4async fn main() -> Result<()> {
5    let api_key = std::env::var("OPENROUTER_API_KEY")?;
6
7    /// The weather tool data
8    #[allow(dead_code)]
9    #[derive(Debug, serde::Deserialize)]
10    struct LocationData {
11        location: String,
12    }
13
14    // send request:
15    let mut response = Completions::openrouter(api_key, "qwen/qwen3-vl-30b-a3b-thinking")
16        .proxy(Proxy::all("socks5://127.0.0.1:1080")?)
17        .user_message(vec!["What's the weather like in London?".into()])
18        .tool(Tool::new(
19            "weather",
20            "Search weather by location",
21            Schema::object("Location data")
22                .required_property("location", Schema::string("The location")),
23        ))
24        .send()
25        .await?;
26
27    // read response stream:
28    let mut tool_calls = vec![];
29    while let Some(chunk) = response.next().await {
30        match chunk? {
31            Chunk::Text(text) => {
32                eprint!("{text}");
33            }
34            Chunk::Tool(name, json_str) => {
35                tool_calls.push((name, json_str));
36            }
37        }
38    }
39    println!();
40
41    // handle tool calls:
42    for (name, json_str) in tool_calls {
43        match name.as_ref() {
44            "weather" => {
45                let location: LocationData = serde_json::from_str(&json_str)?;
46                println!("{location:#?}");
47            }
48            _ => {}
49        }
50    }
51
52    Ok(())
53}

Trait Implementations§

Source§

impl Clone for Tool

Source§

fn clone(&self) -> Tool

Returns a duplicate of the value. Read more
1.0.0 · Source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more
Source§

impl Debug for Tool

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl Default for Tool

Source§

fn default() -> Tool

Returns the “default value” for a type. Read more
Source§

impl<'de> Deserialize<'de> for Tool

Source§

fn deserialize<__D>(__deserializer: __D) -> Result<Self, __D::Error>
where __D: Deserializer<'de>,

Deserialize this value from the given Serde deserializer. Read more
Source§

impl Serialize for Tool

Source§

fn serialize<__S>(&self, __serializer: __S) -> Result<__S::Ok, __S::Error>
where __S: Serializer,

Serialize this value into the given Serde serializer. Read more

Auto Trait Implementations§

§

impl Freeze for Tool

§

impl RefUnwindSafe for Tool

§

impl Send for Tool

§

impl Sync for Tool

§

impl Unpin for Tool

§

impl UnsafeUnpin for Tool

§

impl UnwindSafe for Tool

Blanket Implementations§

Source§

impl<T> Any for T
where T: 'static + ?Sized,

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

impl<T> Borrow<T> for T
where T: ?Sized,

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

impl<T> BorrowMut<T> for T
where T: ?Sized,

Source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T> Instrument for T

Source§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided Span, returning an Instrumented wrapper. Read more
Source§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
Source§

impl<T, U> Into<U> for T
where U: From<T>,

Source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

Source§

impl<T> PolicyExt for T
where T: ?Sized,

Source§

fn and<P, B, E>(self, other: P) -> And<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow only if self and other return Action::Follow. Read more
Source§

fn or<P, B, E>(self, other: P) -> Or<T, P>
where T: Policy<B, E>, P: Policy<B, E>,

Create a new Policy that returns Action::Follow if either self or other returns Action::Follow. Read more
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

type Owned = T

The resulting type after obtaining ownership.
Source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
Source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
Source§

impl<T, U> TryFrom<U> for T
where U: Into<T>,

Source§

type Error = Infallible

The type returned in the event of a conversion error.
Source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
Source§

impl<T, U> TryInto<U> for T
where U: TryFrom<T>,

Source§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
Source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
Source§

impl<T> WithSubscriber for T

Source§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a WithDispatch wrapper. Read more
Source§

impl<T> DeserializeOwned for T
where T: for<'de> Deserialize<'de>,