prompty 2.0.0-alpha.11

Prompty is an asset class and format for LLM prompts
Documentation
// Code generated by AgentSchema emitter; DO NOT EDIT.

#![allow(unused_imports, dead_code, non_camel_case_types, unused_variables, clippy::all)]

use super::super::context::{LoadContext, SaveContext};

/// Timing information for a trace span.
#[derive(Debug, Clone, Default)]
pub struct TraceTime {
    /// ISO 8601 UTC timestamp when the span started
    pub start: String,
    /// ISO 8601 UTC timestamp when the span ended
    pub end: String,
    /// Duration of the span in milliseconds
    pub duration: f64,
}

impl TraceTime {
    /// Create a new TraceTime with default values.
    pub fn new() -> Self {
        Self::default()
    }

    /// Load TraceTime from a JSON string.
    pub fn from_json(json: &str, ctx: &LoadContext) -> Result<Self, serde_json::Error> {
        let value: serde_json::Value = serde_json::from_str(json)?;
        Ok(Self::load_from_value(&value, ctx))
    }

    /// Load TraceTime from a YAML string.
    pub fn from_yaml(yaml: &str, ctx: &LoadContext) -> Result<Self, serde_yaml::Error> {
        let value: serde_json::Value = serde_yaml::from_str(yaml)?;
        Ok(Self::load_from_value(&value, ctx))
    }

    /// Load TraceTime from a `serde_json::Value`.
    ///
    /// Calls `ctx.process_input` before field extraction.
    pub fn load_from_value(value: &serde_json::Value, ctx: &LoadContext) -> Self {
        let value = ctx.process_input(value.clone());
        Self {
            start: value.get("start").and_then(|v| v.as_str()).unwrap_or_default().to_string(),
            end: value.get("end").and_then(|v| v.as_str()).unwrap_or_default().to_string(),
            duration: value.get("duration").and_then(|v| v.as_f64()).unwrap_or(0.0),
        }
    }

    /// Serialize TraceTime to a `serde_json::Value`.
    ///
    /// Calls `ctx.process_dict` after serialization.
    pub fn to_value(&self, ctx: &SaveContext) -> serde_json::Value {
        let mut result = serde_json::Map::new();
        // Write base fields
        if !self.start.is_empty() {
            result.insert("start".to_string(), serde_json::Value::String(self.start.clone()));
        }
        if !self.end.is_empty() {
            result.insert("end".to_string(), serde_json::Value::String(self.end.clone()));
        }
        if self.duration != 0.0 {
            result.insert("duration".to_string(), serde_json::Number::from_f64(self.duration as f64).map(serde_json::Value::Number).unwrap_or(serde_json::Value::Null));
        }
        ctx.process_dict(serde_json::Value::Object(result))
    }

    /// Serialize TraceTime to a JSON string.
    pub fn to_json(&self, ctx: &SaveContext) -> Result<String, serde_json::Error> {
        serde_json::to_string_pretty(&self.to_value(ctx))
    }

    /// Serialize TraceTime to a YAML string.
    pub fn to_yaml(&self, ctx: &SaveContext) -> Result<String, serde_yaml::Error> {
        serde_yaml::to_string(&self.to_value(ctx))
    }
}