litex-lang 0.9.86-beta

A simple formal proof language and verifier, learnable in 2 hours
Documentation
use super::kuratowski_by_stmt::kuratowski_encode_tuple_boxes;
use crate::prelude::*;

impl Runtime {
    pub fn exec_by_tuple_stmt(
        &mut self,
        stmt: &ByTupleAsSetStmt,
    ) -> Result<StmtResult, RuntimeError> {
        let stmt_exec: Stmt = stmt.clone().into();

        let tuple_struct = match &stmt.obj {
            Obj::Tuple(tuple) => tuple.clone(),
            _ => {
                if let Some(t) = self.get_obj_equal_to_tuple(&stmt.obj.to_string()) {
                    t
                } else {
                    return Err(short_exec_error(
                        stmt_exec,
                        format!(
                            "by tuple as set: `{}` is not known to denote a tuple",
                            stmt.obj
                        ),
                        None,
                        vec![],
                    ));
                }
            }
        };

        let verify_state = VerifyState::new(0, false);
        self.verify_obj_well_defined_and_store_cache(&stmt.obj, &verify_state)
            .map_err(|e| {
                short_exec_error(
                    stmt_exec.clone(),
                    format!("by tuple as set: `{}` is not well-defined", stmt.obj),
                    Some(e),
                    vec![],
                )
            })?;

        let encoded = kuratowski_encode_tuple_boxes(&tuple_struct.args).map_err(|msg| {
            short_exec_error(
                stmt_exec.clone(),
                format!("by tuple as set: {}", msg),
                None,
                vec![],
            )
        })?;

        let equal_fact = EqualFact::new(stmt.obj.clone(), encoded, stmt.line_file.clone()).into();

        match self.verify_well_defined_and_store_and_infer_with_default_verify_state(equal_fact) {
            Ok(infer_result) => {
                self.store_tuple_obj_and_cart(
                    &stmt.obj.to_string(),
                    Some(tuple_struct),
                    None,
                    stmt.line_file.clone(),
                );
                Ok((NonFactualStmtSuccess::new(stmt_exec, infer_result, vec![])).into())
            }
            Err(store_error) => Err(short_exec_error(
                stmt_exec,
                "by tuple as set: failed to store definitional equality".to_string(),
                Some(store_error),
                vec![],
            )),
        }
    }
}