use super::common::{SmtCheckResult, SmtChecker, SmtObligation};
use crate::verify::{contract::Property, forward_visit::ForwardVisitResult, helpers::Callsite};
pub(crate) fn check<'tcx>(
checker: &SmtChecker<'tcx>,
callsite: &Callsite<'tcx>,
property: &Property<'tcx>,
forward: &ForwardVisitResult<'tcx>,
) -> SmtCheckResult {
let Some(target) = checker.property_target(callsite, property) else {
return SmtCheckResult::unknown("InBound target could not be resolved");
};
let Some(required_ty) = checker.property_required_ty(callsite, property) else {
return SmtCheckResult::unknown("InBound type could not be resolved");
};
let Some((_, elem_size)) = checker.type_layout(callsite.caller, required_ty) else {
return SmtCheckResult::unknown(format!(
"InBound layout unavailable for {:?}",
required_ty
));
};
let Some(access_count) = checker.property_len_const(property) else {
return SmtCheckResult::unknown(
"InBound currently requires a constant element-count argument",
);
};
checker.prove_obligation(
callsite,
forward,
SmtObligation::InBounds {
place: target,
ty_name: format!("{required_ty:?}"),
elem_size,
access_count,
},
)
}