Expand function calls throughout a vl-arguments-p
(vl-arguments-expand-function-calls x ss nf vardecls assigns warnings ctx loc) → (mv successp warnings nf x-prime vardecls assigns)
Function:
(defun vl-arguments-expand-function-calls (x ss nf vardecls assigns warnings ctx loc) (declare (xargs :guard (and (vl-arguments-p x) (vl-scopestack-p ss) (vl-namefactory-p nf) (vl-vardecllist-p vardecls) (vl-assignlist-p assigns) (vl-warninglist-p warnings) (vl-context-p ctx) (vl-location-p loc)))) (let ((__function__ 'vl-arguments-expand-function-calls)) (declare (ignorable __function__)) (b* ((nf (vl-namefactory-fix nf)) (assigns (vl-assignlist-fix assigns)) (vardecls (vl-vardecllist-fix vardecls))) (b* ((x (vl-arguments-fix x)) ((unless (vl-exprlist-has-funcalls (vl-arguments-allexprs x))) (mv t (ok) nf x vardecls assigns)) ((when (eq (vl-arguments-kind x) :vl-arguments-named)) (mv nil (fatal :type :vl-bad-instance :msg "In ~a0, we expected all arguments to be resolved ~ before function expansion." :args (list ctx)) nf x vardecls assigns)) ((mv okp warnings nf args-prime vardecls assigns) (vl-plainarglist-expand-function-calls (vl-arguments-plain->args x) ss nf vardecls assigns warnings ctx loc)) (x-prime (make-vl-arguments-plain :args args-prime))) (mv okp warnings nf x-prime vardecls assigns)))))
Theorem:
(defthm booleanp-of-vl-arguments-expand-function-calls.successp (b* (((mv ?successp ?warnings ?nf ?x-prime ?vardecls ?assigns) (vl-arguments-expand-function-calls x ss nf vardecls assigns warnings ctx loc))) (booleanp successp)) :rule-classes :type-prescription)
Theorem:
(defthm vl-warninglist-p-of-vl-arguments-expand-function-calls.warnings (b* (((mv ?successp ?warnings ?nf ?x-prime ?vardecls ?assigns) (vl-arguments-expand-function-calls x ss nf vardecls assigns warnings ctx loc))) (vl-warninglist-p warnings)) :rule-classes :rewrite)
Theorem:
(defthm vl-namefactory-p-of-vl-arguments-expand-function-calls.nf (b* (((mv ?successp ?warnings ?nf ?x-prime ?vardecls ?assigns) (vl-arguments-expand-function-calls x ss nf vardecls assigns warnings ctx loc))) (vl-namefactory-p nf)) :rule-classes :rewrite)
Theorem:
(defthm vl-arguments-p-of-vl-arguments-expand-function-calls.x-prime (b* (((mv ?successp ?warnings ?nf ?x-prime ?vardecls ?assigns) (vl-arguments-expand-function-calls x ss nf vardecls assigns warnings ctx loc))) (vl-arguments-p x-prime)) :rule-classes :rewrite)
Theorem:
(defthm vl-vardecllist-p-of-vl-arguments-expand-function-calls.vardecls (b* (((mv ?successp ?warnings ?nf ?x-prime ?vardecls ?assigns) (vl-arguments-expand-function-calls x ss nf vardecls assigns warnings ctx loc))) (vl-vardecllist-p vardecls)) :rule-classes :rewrite)
Theorem:
(defthm vl-assignlist-p-of-vl-arguments-expand-function-calls.assigns (b* (((mv ?successp ?warnings ?nf ?x-prime ?vardecls ?assigns) (vl-arguments-expand-function-calls x ss nf vardecls assigns warnings ctx loc))) (vl-assignlist-p assigns)) :rule-classes :rewrite)