Skip to main content

mistral_openapi_client/models/
think_chunk.rs

1/*
2 * Mistral AI API
3 *
4 * Our Chat Completion and Embeddings APIs specification. Create your account on [La Plateforme](https://console.mistral.ai) to get access and read the [docs](https://docs.mistral.ai) to learn how to use it.
5 *
6 * The version of the OpenAPI document: 1.0.0
7 * 
8 * Generated by: https://openapi-generator.tech
9 */
10
11use crate::models;
12use serde::{Deserialize, Serialize};
13
14#[derive(Clone, Default, Debug, PartialEq, Serialize, Deserialize)]
15pub struct ThinkChunk {
16    #[serde(rename = "type", skip_serializing_if = "Option::is_none")]
17    pub r#type: Option<Type>,
18    #[serde(rename = "thinking")]
19    pub thinking: Vec<models::ThinkingInner>,
20    /// Whether the thinking chunk is closed or not. Currently only used for prefixing.
21    #[serde(rename = "closed", skip_serializing_if = "Option::is_none")]
22    pub closed: Option<bool>,
23}
24
25impl ThinkChunk {
26    pub fn new(thinking: Vec<models::ThinkingInner>) -> ThinkChunk {
27        ThinkChunk {
28            r#type: None,
29            thinking,
30            closed: None,
31        }
32    }
33}
34/// 
35#[derive(Clone, Copy, Debug, Eq, PartialEq, Ord, PartialOrd, Hash, Serialize, Deserialize)]
36pub enum Type {
37    #[serde(rename = "thinking")]
38    Thinking,
39}
40
41impl Default for Type {
42    fn default() -> Type {
43        Self::Thinking
44    }
45}
46