(vl-always-stmtrewrite x unroll-limit warnings) → (mv warnings new-x)
Function:
(defun vl-always-stmtrewrite (x unroll-limit warnings) (declare (xargs :guard (and (vl-always-p x) (natp unroll-limit) (vl-warninglist-p warnings)))) (let ((__function__ 'vl-always-stmtrewrite)) (declare (ignorable __function__)) (b* (((mv warnings stmt) (vl-stmt-rewrite-top (vl-always->stmt x) unroll-limit warnings)) (x-prime (change-vl-always x :stmt stmt))) (mv warnings x-prime))))
Theorem:
(defthm vl-warninglist-p-of-vl-always-stmtrewrite.warnings (implies (and (force (vl-always-p x)) (force (natp unroll-limit)) (force (vl-warninglist-p warnings))) (b* (((mv ?warnings ?new-x) (vl-always-stmtrewrite x unroll-limit warnings))) (vl-warninglist-p warnings))) :rule-classes :rewrite)
Theorem:
(defthm vl-always-p-of-vl-always-stmtrewrite.new-x (implies (and (force (vl-always-p x)) (force (natp unroll-limit)) (force (vl-warninglist-p warnings))) (b* (((mv ?warnings ?new-x) (vl-always-stmtrewrite x unroll-limit warnings))) (vl-always-p new-x))) :rule-classes :rewrite)