prompty 2.0.0-beta.1

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

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

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

use super::validation_error::ValidationError;

/// The result of validating inputs against a Prompty's inputs. Returned by `validate_inputs` (ยง12.2) to indicate whether all required inputs are present and satisfy their constraints.
#[derive(Debug, Clone, Default)]
pub struct ValidationResult {
    /// Whether all inputs passed validation
    pub valid: bool,
    /// List of validation errors (empty when valid is true)
    pub errors: Vec<ValidationError>,
}

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

    /// Load ValidationResult 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 ValidationResult 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 ValidationResult 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 {
            valid: value
                .get("valid")
                .and_then(|v| v.as_bool())
                .unwrap_or(false),
            errors: value
                .get("errors")
                .map(|v| Self::load_errors(v, ctx))
                .unwrap_or_default(),
        }
    }

    /// Serialize ValidationResult 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
        result.insert("valid".to_string(), serde_json::Value::Bool(self.valid));
        if !self.errors.is_empty() {
            result.insert("errors".to_string(), Self::save_errors(&self.errors, ctx));
        }
        ctx.process_dict(serde_json::Value::Object(result))
    }

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

    /// Load a collection of ValidationError from a JSON value.
    /// Handles both array format `[{...}]`.
    fn load_errors(data: &serde_json::Value, ctx: &LoadContext) -> Vec<ValidationError> {
        match data {
            serde_json::Value::Array(arr) => arr
                .iter()
                .map(|v| ValidationError::load_from_value(v, ctx))
                .collect(),

            _ => Vec::new(),
        }
    }

    /// Save a collection of ValidationError to a JSON value.
    fn save_errors(items: &[ValidationError], ctx: &SaveContext) -> serde_json::Value {
        serde_json::Value::Array(
            items
                .iter()
                .map(|item| item.to_value(ctx))
                .collect::<Vec<_>>(),
        )
    }
}