Check and size an index expression in an unpacked type context.
(vl-index-expr-size-assigncontext lhs-type x ss ctx warnings) → (mv successp new-x new-warnings)
Function:
(defun vl-index-expr-size-assigncontext (lhs-type x ss ctx warnings) (declare (xargs :guard (and (vl-datatype-p lhs-type) (vl-expr-p x) (vl-scopestack-p ss) (vl-context-p ctx) (vl-warninglist-p warnings)))) (let ((__function__ 'vl-index-expr-size-assigncontext)) (declare (ignorable __function__)) (b* ((x (vl-expr-fix x)) (ctx (vl-context-fix ctx)) ((mv warning type) (vl-index-find-type x ss ctx)) ((when warning) (mv nil x (cons warning (ok)))) ((unless (equal type (vl-datatype-fix lhs-type))) (mv nil x (warn :type :vl-assignpattern-elim-fail :msg "~a0: RHS expression ~a1 is not of type ~a2 (rather, ~a3)" :args (list ctx x (vl-datatype-fix lhs-type) type))))) (mv t x (ok)))))
Theorem:
(defthm booleanp-of-vl-index-expr-size-assigncontext.successp (b* (((mv ?successp ?new-x ?new-warnings) (vl-index-expr-size-assigncontext lhs-type x ss ctx warnings))) (booleanp successp)) :rule-classes :type-prescription)
Theorem:
(defthm vl-expr-p-of-vl-index-expr-size-assigncontext.new-x (b* (((mv ?successp ?new-x ?new-warnings) (vl-index-expr-size-assigncontext lhs-type x ss ctx warnings))) (vl-expr-p new-x)) :rule-classes :rewrite)
Theorem:
(defthm vl-warninglist-p-of-vl-index-expr-size-assigncontext.new-warnings (b* (((mv ?successp ?new-x ?new-warnings) (vl-index-expr-size-assigncontext lhs-type x ss ctx warnings))) (vl-warninglist-p new-warnings)) :rule-classes :rewrite)
Theorem:
(defthm vl-expr-selfsize-of-vl-index-expr-size-assigncontext (b* (((mv ok new-x &) (vl-index-expr-size-assigncontext lhs-type x ss ctx warnings)) ((mv warning typesize) (vl-datatype-size lhs-type)) ((mv & selfsize) (vl-expr-selfsize new-x ss ctx2 warnings2))) (implies (and ok (not warning)) (equal selfsize typesize))))
Theorem:
(defthm vl-index-expr-size-assigncontext-of-vl-datatype-fix-lhs-type (equal (vl-index-expr-size-assigncontext (vl-datatype-fix lhs-type) x ss ctx warnings) (vl-index-expr-size-assigncontext lhs-type x ss ctx warnings)))
Theorem:
(defthm vl-index-expr-size-assigncontext-vl-datatype-equiv-congruence-on-lhs-type (implies (vl-datatype-equiv lhs-type lhs-type-equiv) (equal (vl-index-expr-size-assigncontext lhs-type x ss ctx warnings) (vl-index-expr-size-assigncontext lhs-type-equiv x ss ctx warnings))) :rule-classes :congruence)
Theorem:
(defthm vl-index-expr-size-assigncontext-of-vl-expr-fix-x (equal (vl-index-expr-size-assigncontext lhs-type (vl-expr-fix x) ss ctx warnings) (vl-index-expr-size-assigncontext lhs-type x ss ctx warnings)))
Theorem:
(defthm vl-index-expr-size-assigncontext-vl-expr-equiv-congruence-on-x (implies (vl-expr-equiv x x-equiv) (equal (vl-index-expr-size-assigncontext lhs-type x ss ctx warnings) (vl-index-expr-size-assigncontext lhs-type x-equiv ss ctx warnings))) :rule-classes :congruence)
Theorem:
(defthm vl-index-expr-size-assigncontext-of-vl-scopestack-fix-ss (equal (vl-index-expr-size-assigncontext lhs-type x (vl-scopestack-fix ss) ctx warnings) (vl-index-expr-size-assigncontext lhs-type x ss ctx warnings)))
Theorem:
(defthm vl-index-expr-size-assigncontext-vl-scopestack-equiv-congruence-on-ss (implies (vl-scopestack-equiv ss ss-equiv) (equal (vl-index-expr-size-assigncontext lhs-type x ss ctx warnings) (vl-index-expr-size-assigncontext lhs-type x ss-equiv ctx warnings))) :rule-classes :congruence)
Theorem:
(defthm vl-index-expr-size-assigncontext-of-vl-context-fix-ctx (equal (vl-index-expr-size-assigncontext lhs-type x ss (vl-context-fix ctx) warnings) (vl-index-expr-size-assigncontext lhs-type x ss ctx warnings)))
Theorem:
(defthm vl-index-expr-size-assigncontext-vl-context-equiv-congruence-on-ctx (implies (vl-context-equiv ctx ctx-equiv) (equal (vl-index-expr-size-assigncontext lhs-type x ss ctx warnings) (vl-index-expr-size-assigncontext lhs-type x ss ctx-equiv warnings))) :rule-classes :congruence)
Theorem:
(defthm vl-index-expr-size-assigncontext-of-vl-warninglist-fix-warnings (equal (vl-index-expr-size-assigncontext lhs-type x ss ctx (vl-warninglist-fix warnings)) (vl-index-expr-size-assigncontext lhs-type x ss ctx warnings)))
Theorem:
(defthm vl-index-expr-size-assigncontext-vl-warninglist-equiv-congruence-on-warnings (implies (vl-warninglist-equiv warnings warnings-equiv) (equal (vl-index-expr-size-assigncontext lhs-type x ss ctx warnings) (vl-index-expr-size-assigncontext lhs-type x ss ctx warnings-equiv))) :rule-classes :congruence)