aprender-contracts 0.34.0

Papers to Math to Contracts in Code — YAML contract parsing, validation, scaffold generation, and Kani harness codegen for provable Rust kernels
Documentation
//! Example: Query contracts using BM25 semantic search.
//!
//! ```bash
//! cargo run --example query
//! ```

use std::path::Path;

use provable_contracts::query::{self, ContractIndex, QueryParams};

fn main() {
    let contracts_dir = Path::new("contracts");
    let index =
        ContractIndex::from_directory(contracts_dir).expect("contracts/ directory must exist");

    println!("Indexed {} contracts\n", index.entries.len());

    // Semantic search with score + proof-status enrichment
    let params = QueryParams {
        query: "softmax numerical stability".to_string(),
        limit: 3,
        show_score: true,
        show_proof_status: true,
        show_paper: true,
        ..Default::default()
    };
    let output = query::execute(&index, &params);
    print!("{output}");

    // Literal search
    println!("\n--- Literal search for 'RMSNorm' ---\n");
    let params = QueryParams {
        query: "RMSNorm".to_string(),
        mode: query::SearchMode::Literal,
        limit: 3,
        ..Default::default()
    };
    let output = query::execute(&index, &params);
    print!("{output}");

    // Filtered search with obligation type
    println!("\n--- Invariant obligations only ---\n");
    let params = QueryParams {
        query: "kernel".to_string(),
        obligation_filter: Some("invariant".to_string()),
        limit: 5,
        ..Default::default()
    };
    let output = query::execute(&index, &params);
    print!("{output}");

    // Markdown output
    println!("\n--- Markdown format ---\n");
    let params = QueryParams {
        query: "rmsnorm".to_string(),
        show_score: true,
        show_paper: true,
        limit: 2,
        ..Default::default()
    };
    let output = query::execute(&index, &params);
    print!("{}", output.to_markdown());

    // Score cache lookup (O(1))
    println!("\n--- Score cache ---\n");
    if let Some(score) = index.cached_score("softmax-kernel-v1") {
        println!("softmax-kernel-v1 cached score: {score:.2}");
    }
    if let Some(score) = index.cached_score("rmsnorm-kernel-v1") {
        println!("rmsnorm-kernel-v1 cached score: {score:.2}");
    }

    // Binding enrichment
    let binding_path = Path::new("contracts/aprender/binding.yaml");
    if binding_path.exists() {
        println!("\n--- Binding enrichment ---\n");
        let params = QueryParams {
            query: "softmax".to_string(),
            show_binding: true,
            binding_path: Some(binding_path.display().to_string()),
            limit: 2,
            ..Default::default()
        };
        let output = query::execute(&index, &params);
        print!("{output}");
    }

    // Diff enrichment — show last git modification date
    println!("\n--- Diff enrichment ---\n");
    let params = QueryParams {
        query: "rmsnorm".to_string(),
        show_diff: true,
        limit: 3,
        ..Default::default()
    };
    let output = query::execute(&index, &params);
    print!("{output}");

    // Min-level filter — only L3+ contracts
    println!("\n--- L3+ contracts only ---\n");
    let params = QueryParams {
        query: "softmax".to_string(),
        min_level: Some("L3".to_string()),
        show_proof_status: true,
        limit: 3,
        ..Default::default()
    };
    let output = query::execute(&index, &params);
    print!("{output}");

    // PageRank — contract importance scores
    println!("\n--- PageRank (top 5 most depended-upon) ---\n");
    let mut pr: Vec<_> = index
        .entries
        .iter()
        .filter_map(|e| index.cached_pagerank(&e.stem).map(|s| (&e.stem, s)))
        .collect();
    pr.sort_by(|a, b| b.1.partial_cmp(&a.1).unwrap());
    for (stem, score) in pr.iter().take(5) {
        println!("  {stem}: {score:.4}");
    }
}