panproto-inst 0.48.1

Instance representation for panproto
Documentation
//! # panproto-inst
//!
//! Instance representation for panproto (attributed C-sets).
//!
//! This crate provides three instance shapes, unified under [`Instance`]:
//!
//! - **[`WInstance`]**: Tree-shaped (W-type) instances with nodes,
//!   arcs, and optional hyper-edge fans.
//! - **[`FInstance`]**: Relational (set-valued functor) instances
//!   with tables and foreign keys.
//! - **[`GInstance`]**: Graph-shaped instances with nodes and edges
//!   (most general form, no root, cycles allowed).
//!
//! All three are attributed C-sets over different shape categories.
//! The [`Instance`] enum provides a unified interface.

// Allow concrete HashMap/HashSet in public API signatures per ENGINEERING.md spec.
#![allow(clippy::implicit_hasher)]

/// Generic attributed C-set trait unifying all instance shapes.
pub mod acset;
/// Incremental contraction tracker for ancestor contraction.
pub mod contraction;
/// Edit errors for tree and table edits.
pub mod edit_error;
/// Operations on the category of elements `∫F` (Grothendieck construction).
pub mod element_ops;
/// Error types for instance operations.
pub mod error;
/// Hyperedge fan representation.
pub mod fan;
/// Set-valued functor instance representation.
pub mod functor;
/// Graph-shaped instance representation.
pub mod ginstance;
/// Internal hom schema construction and evaluation.
pub mod hom;
/// Unified instance enum (attributed C-set).
pub mod instance;
/// Instance-aware expression evaluation (graph traversal builtins).
pub mod instance_env;
/// Metadata types for instance nodes.
pub mod metadata;
/// JSON parsing for W-type instances.
pub mod parse;
/// Right Kan extension (Pi_F) for instances.
pub mod pi;
/// Polynomial functor operations (fiber, group-by, join, section).
pub mod poly;
/// W-type instance representation and the `wtype_restrict` pipeline.
pub mod provenance;
/// Declarative query engine for instance presheaves.
pub mod query;
/// Incremental reachability index for W-type instances.
pub mod reachability;
/// Edit algebra for functor (table-shaped) instances.
pub mod table_edit;
/// Edit algebra for W-type (tree-shaped) instances.
pub mod tree_edit;
/// Validation of W-type instances against schemas.
pub mod validate;
/// Value types and field presence.
pub mod value;
pub mod wtype;

// Re-exports for convenience.
pub use acset::AcsetOps;
pub use contraction::{ContractionRecord, ContractionTracker};
pub use edit_error::EditError;
pub use element_ops::{ElementOps, decode_finstance_id, encode_finstance_id};
pub use error::{InstError, ParseError, RestrictError, ValidationError};
pub use fan::Fan;
pub use functor::{FInstance, functor_extend, functor_restrict};
pub use ginstance::{GInstance, graph_extend, graph_restrict};
pub use hom::{curry_migration, eval_hom, hom_schema};
pub use instance::Instance;
pub use instance_env::{eval_with_element_ops, eval_with_instance};
pub use metadata::{Node, NodeShape};
pub use parse::{parse_json, to_json};
pub use pi::{functor_pi, wtype_pi};
pub use poly::{
    Complement, DroppedNode, SectionEnrichment, fiber_at_anchor, fiber_at_node,
    fiber_decomposition, fiber_with_predicate, group_by, join, restrict_with_complement, section,
};
pub use provenance::{Provenance, ProvenanceMap, SourceField, TransformStep, compute_provenance};
pub use query::{
    InstanceQuery, QueryMatch, build_node_env, execute as execute_query, execute_any,
    execute_elements, execute_functor, execute_graph,
};
pub use reachability::ReachabilityIndex;
pub use table_edit::TableEdit;
pub use tree_edit::TreeEdit;
pub use validate::validate_wtype;
pub use value::{FieldPresence, Value};
pub use wtype::{
    CaseBranch, CompiledMigration, FieldTransform, WInstance, ancestor_contraction,
    anchor_surviving, build_env_from_extra_fields, build_env_with_children,
    collect_scalar_child_values, expr_literal_to_value, reconstruct_fans, resolve_edge,
    value_to_expr_literal, wtype_extend, wtype_restrict,
};